diff --git a/src/chatlog/chatlog.cpp b/src/chatlog/chatlog.cpp index 35da7f38b..e0c5e7637 100644 --- a/src/chatlog/chatlog.cpp +++ b/src/chatlog/chatlog.cpp @@ -22,6 +22,7 @@ #include "chatlinecontentproxy.h" #include "chatmessage.h" #include "content/filetransferwidget.h" +#include "src/widget/gui.h" #include "src/widget/translator.h" #include "src/widget/style.h" @@ -121,6 +122,9 @@ ChatLog::ChatLog(QWidget* parent) copySelectedText(true); }); + connect(&GUI::getInstance(), &GUI::themeReload, this, &ChatLog::reloadTheme); + + reloadTheme(); retranslateUi(); Translator::registerHandler(std::bind(&ChatLog::retranslateUi, this), this); } @@ -718,6 +722,7 @@ void ChatLog::fontChanged(const QFont& font) void ChatLog::reloadTheme() { + setStyleSheet(Style::getStylesheet("chatArea/chatArea.css")); setBackgroundBrush(QBrush(Style::getColor(Style::GroundBase), Qt::SolidPattern)); selectionRectColor = Style::getColor(Style::SelectText); selGraphItem->setBrush(QBrush(selectionRectColor)); diff --git a/src/chatlog/chatlog.h b/src/chatlog/chatlog.h index 30eb0a872..6d5b3bf49 100644 --- a/src/chatlog/chatlog.h +++ b/src/chatlog/chatlog.h @@ -56,7 +56,6 @@ public: void scrollToLine(ChatLine::Ptr line); void selectAll(); void fontChanged(const QFont& font); - void reloadTheme(); void removeFirsts(const int num); void removeLasts(const int num); void setScroll(const bool scroll); @@ -83,6 +82,7 @@ signals: public slots: void forceRelayout(); + void reloadTheme(); private slots: void onSelectionTimerTimeout(); diff --git a/src/chatlog/content/filetransferwidget.cpp b/src/chatlog/content/filetransferwidget.cpp index ef5599cba..6e62d5a59 100644 --- a/src/chatlog/content/filetransferwidget.cpp +++ b/src/chatlog/content/filetransferwidget.cpp @@ -90,6 +90,8 @@ FileTransferWidget::FileTransferWidget(QWidget* parent, CoreFile& _coreFile, Tox connect(ui->previewButton, &QPushButton::clicked, this, &FileTransferWidget::onPreviewButtonClicked); + connect(&GUI::getInstance(), &GUI::themeReload, this, &FileTransferWidget::reloadTheme); + // Set lastStatus to anything but the file's current value, this forces an update lastStatus = file.status == ToxFile::FINISHED ? ToxFile::INITIALIZING : ToxFile::FINISHED; updateWidget(file); @@ -227,6 +229,11 @@ void FileTransferWidget::paintEvent(QPaintEvent*) } } +void FileTransferWidget::reloadTheme() +{ + updateBackgroundColor(lastStatus); +} + QString FileTransferWidget::getHumanReadableSize(qint64 size) { static const char* suffix[] = {"B", "KiB", "MiB", "GiB", "TiB"}; @@ -245,23 +252,7 @@ void FileTransferWidget::updateWidgetColor(ToxFile const& file) return; } - switch (file.status) { - case ToxFile::INITIALIZING: - case ToxFile::PAUSED: - case ToxFile::TRANSMITTING: - setBackgroundColor(Style::getColor(Style::TransferMiddle), false); - break; - case ToxFile::BROKEN: - case ToxFile::CANCELED: - setBackgroundColor(Style::getColor(Style::TransferBad), true); - break; - case ToxFile::FINISHED: - setBackgroundColor(Style::getColor(Style::TransferGood), true); - break; - default: - qCritical() << "Invalid file status"; - assert(false); - } + updateBackgroundColor(file.status); } void FileTransferWidget::updateWidgetText(ToxFile const& file) @@ -623,3 +614,24 @@ void FileTransferWidget::updateWidget(ToxFile const& file) update(); } } + +void FileTransferWidget::updateBackgroundColor(const ToxFile::FileStatus status) +{ + switch (status) { + case ToxFile::INITIALIZING: + case ToxFile::PAUSED: + case ToxFile::TRANSMITTING: + setBackgroundColor(Style::getColor(Style::TransferMiddle), false); + break; + case ToxFile::BROKEN: + case ToxFile::CANCELED: + setBackgroundColor(Style::getColor(Style::TransferBad), true); + break; + case ToxFile::FINISHED: + setBackgroundColor(Style::getColor(Style::TransferGood), true); + break; + default: + qCritical() << "Invalid file status"; + assert(false); + } +} diff --git a/src/chatlog/content/filetransferwidget.h b/src/chatlog/content/filetransferwidget.h index 087969d3a..88face59d 100644 --- a/src/chatlog/content/filetransferwidget.h +++ b/src/chatlog/content/filetransferwidget.h @@ -64,6 +64,9 @@ protected: void paintEvent(QPaintEvent*) final; +public slots: + void reloadTheme(); + private slots: void onLeftButtonClicked(); void onRightButtonClicked(); @@ -76,6 +79,7 @@ private: static bool tryRemoveFile(const QString &filepath); void updateWidget(ToxFile const& file); + void updateBackgroundColor(const ToxFile::FileStatus status); private: CoreFile& coreFile; diff --git a/src/widget/about/aboutfriendform.cpp b/src/widget/about/aboutfriendform.cpp index 7390291a5..ea27f22a0 100644 --- a/src/widget/about/aboutfriendform.cpp +++ b/src/widget/about/aboutfriendform.cpp @@ -67,7 +67,9 @@ AboutFriendForm::AboutFriendForm(std::unique_ptr _about, QWidget* ui->statusMessage->setText(about->getStatusMessage()); ui->avatar->setPixmap(about->getAvatar()); - setStyleSheet(Style::getStylesheet("window/general.css")); + connect(&GUI::getInstance(), &GUI::themeReload, this, &AboutFriendForm::reloadTheme); + + reloadTheme(); } static QString getAutoAcceptDir(const QString& dir) @@ -90,6 +92,11 @@ void AboutFriendForm::onAutoAcceptDirClicked() about->setAutoAcceptDir(dir); } +void AboutFriendForm::reloadTheme() +{ + setStyleSheet(Style::getStylesheet("window/general.css")); +} + void AboutFriendForm::onAutoAcceptDirChanged(const QString& path) { const bool enabled = !path.isNull(); diff --git a/src/widget/about/aboutfriendform.h b/src/widget/about/aboutfriendform.h index 66acdf0e8..c9088c3d0 100644 --- a/src/widget/about/aboutfriendform.h +++ b/src/widget/about/aboutfriendform.h @@ -45,6 +45,9 @@ private: signals: void histroyRemoved(); +public slots: + void reloadTheme(); + private slots: void onAutoAcceptDirChanged(const QString& path); void onAcceptedClicked(); diff --git a/src/widget/chatformheader.cpp b/src/widget/chatformheader.cpp index 97f91b720..6cd708054 100644 --- a/src/widget/chatformheader.cpp +++ b/src/widget/chatformheader.cpp @@ -19,6 +19,7 @@ #include "chatformheader.h" +#include "src/widget/gui.h" #include "src/widget/maskablepixmapwidget.h" #include "src/widget/style.h" #include "src/widget/tool/callconfirmwidget.h" @@ -154,6 +155,8 @@ ChatFormHeader::ChatFormHeader(QWidget* parent) updateButtonsView(); Translator::registerHandler(std::bind(&ChatFormHeader::retranslateUi, this), this); + + connect(&GUI::getInstance(), &GUI::themeReload, this, &ChatFormHeader::reloadTheme); } ChatFormHeader::~ChatFormHeader() = default; @@ -283,6 +286,7 @@ 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)); diff --git a/src/widget/chatformheader.h b/src/widget/chatformheader.h index fa37f3f1a..7e39a8f23 100644 --- a/src/widget/chatformheader.h +++ b/src/widget/chatformheader.h @@ -71,13 +71,14 @@ public: void setAvatar(const QPixmap& img); QSize getAvatarSize() const; - void reloadTheme(); - // TODO: Remove void addWidget(QWidget* widget, int stretch = 0, Qt::Alignment alignment = Qt::Alignment()); void addLayout(QLayout* layout); void addStretch(); +public slots: + void reloadTheme(); + signals: void callTriggered(); void videoCallTriggered(); diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp index 2a4bffc42..ff3077b11 100644 --- a/src/widget/contentdialog.cpp +++ b/src/widget/contentdialog.cpp @@ -59,8 +59,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent) , videoSurfaceSize(QSize()) , videoCount(0) { - const Settings& s = Settings::getInstance(); - setStyleSheet(Style::getStylesheet("contentDialog/contentDialog.css")); + const Settings& s = Settings::getInstance(); friendLayout->setMargin(0); friendLayout->setSpacing(0); @@ -83,12 +82,11 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent) onGroupchatPositionChanged(s.getGroupchatPosition()); - QScrollArea* friendScroll = new QScrollArea(this); + friendScroll = new QScrollArea(this); friendScroll->setMinimumWidth(minWidget); friendScroll->setFrameStyle(QFrame::NoFrame); friendScroll->setLayoutDirection(Qt::RightToLeft); friendScroll->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); - friendScroll->setStyleSheet(Style::getStylesheet("friendList/friendList.css")); friendScroll->setWidgetResizable(true); friendScroll->setWidget(friendWidget); @@ -128,6 +126,8 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent) setAcceptDrops(true); + reloadTheme(); + new QShortcut(Qt::CTRL + Qt::Key_Q, this, SLOT(close())); new QShortcut(Qt::CTRL + Qt::SHIFT + Qt::Key_Tab, this, SLOT(previousContact())); new QShortcut(Qt::CTRL + Qt::Key_Tab, this, SLOT(nextContact())); @@ -435,6 +435,12 @@ void ContentDialog::setUsername(const QString& newName) updateTitleAndStatusIcon(); } +void ContentDialog::reloadTheme() +{ + setStyleSheet(Style::getStylesheet("contentDialog/contentDialog.css")); + friendScroll->setStyleSheet(Style::getStylesheet("friendList/friendList.css")); +} + bool ContentDialog::event(QEvent* event) { switch (event->type()) { diff --git a/src/widget/contentdialog.h b/src/widget/contentdialog.h index 519f85f6a..8e6d6386c 100644 --- a/src/widget/contentdialog.h +++ b/src/widget/contentdialog.h @@ -44,6 +44,7 @@ class GroupChatroom; class GroupWidget; class QCloseEvent; class QSplitter; +class QScrollArea; class ContentDialog : public ActivateDialog, public IDialogs { @@ -90,6 +91,7 @@ public slots: void previousContact(); void nextContact(); void setUsername(const QString& newName); + void reloadTheme() override; protected: bool event(QEvent* event) final; @@ -121,6 +123,7 @@ private: private: QList layouts; QSplitter* splitter; + QScrollArea* friendScroll; FriendListLayout* friendLayout; GenericChatItemLayout groupLayout; ContentLayout* contentLayout; diff --git a/src/widget/contentlayout.cpp b/src/widget/contentlayout.cpp index 4fa772b2e..d72c792f1 100644 --- a/src/widget/contentlayout.cpp +++ b/src/widget/contentlayout.cpp @@ -20,6 +20,7 @@ #include "contentlayout.h" #include "style.h" #include "src/persistence/settings.h" +#include "src/widget/gui.h" #include #include @@ -118,6 +119,8 @@ void ContentLayout::init() mainContent->setStyle(QStyleFactory::create(Settings::getInstance().getStyle())); } + connect(&GUI::getInstance(), &GUI::themeReload, this, &ContentLayout::reloadTheme); + reloadTheme(); mainHLineLayout.addSpacing(4); diff --git a/src/widget/contentlayout.h b/src/widget/contentlayout.h index 5200dfde7..fd315a45e 100644 --- a/src/widget/contentlayout.h +++ b/src/widget/contentlayout.h @@ -29,7 +29,6 @@ public: explicit ContentLayout(QWidget* parent); ~ContentLayout(); - void reloadTheme(); void clear(); QFrame mainHLine; @@ -37,6 +36,9 @@ public: QWidget* mainContent; QWidget* mainHead; +public slots: + void reloadTheme(); + private: void init(); }; diff --git a/src/widget/form/chatform.h b/src/widget/form/chatform.h index 045a82984..318980393 100644 --- a/src/widget/form/chatform.h +++ b/src/widget/form/chatform.h @@ -53,7 +53,6 @@ public: void setFriendTyping(bool isTyping); void show(ContentLayout* contentLayout) final; - void reloadTheme() final; static const QString ACTION_PREFIX; @@ -76,6 +75,7 @@ public slots: void clearChatArea(); void onShowMessagesClicked(); void onSplitterMoved(int pos, int index); + void reloadTheme() final; private slots: void updateFriendActivityForFile(const ToxFile& file); diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 078706e1c..10d974c1d 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -36,6 +36,7 @@ #include "src/widget/contentlayout.h" #include "src/widget/emoticonswidget.h" #include "src/widget/form/chatform.h" +#include "src/widget/gui.h" #include "src/widget/maskablepixmapwidget.h" #include "src/widget/searchform.h" #include "src/widget/style.h" @@ -335,6 +336,8 @@ GenericChatForm::GenericChatForm(const Core& _core, const Contact* contact, ICha connect(msgEdit, &ChatTextEdit::enterPressed, this, &GenericChatForm::onSendTriggered); + connect(&GUI::getInstance(), &GUI::themeReload, this, &GenericChatForm::reloadTheme); + reloadTheme(); fileFlyout->setFixedSize(FILE_FLYOUT_SIZE); @@ -414,12 +417,6 @@ void GenericChatForm::reloadTheme() msgEdit->setStyleSheet(Style::getStylesheet("msgEdit/msgEdit.css") + fontToCss(s.getChatMessageFont(), "QTextEdit")); - chatWidget->setStyleSheet(Style::getStylesheet("chatArea/chatArea.css")); - headWidget->setStyleSheet(Style::getStylesheet("chatArea/chatHead.css")); - chatWidget->reloadTheme(); - headWidget->reloadTheme(); - searchForm->reloadTheme(); - emoteButton->setStyleSheet(Style::getStylesheet(STYLE_PATH)); fileButton->setStyleSheet(Style::getStylesheet(STYLE_PATH)); screenshotButton->setStyleSheet(Style::getStylesheet(STYLE_PATH)); diff --git a/src/widget/form/genericchatform.h b/src/widget/form/genericchatform.h index 8173f896a..01a2c1f8f 100644 --- a/src/widget/form/genericchatform.h +++ b/src/widget/form/genericchatform.h @@ -75,7 +75,6 @@ public: void setName(const QString& newName); virtual void show(ContentLayout* contentLayout); - virtual void reloadTheme(); void addSystemInfoMessage(const QString& message, ChatMessage::SystemMessageType type, const QDateTime& datetime); @@ -91,6 +90,7 @@ public slots: void focusInput(); void onChatMessageFontChanged(const QFont& font); void setColorizedNames(bool enable); + virtual void reloadTheme(); protected slots: void onChatContextMenuRequested(QPoint pos); diff --git a/src/widget/form/settings/aboutform.cpp b/src/widget/form/settings/aboutform.cpp index f82886447..65d4c056d 100644 --- a/src/widget/form/settings/aboutform.cpp +++ b/src/widget/form/settings/aboutform.cpp @@ -182,6 +182,11 @@ void AboutForm::onUpdateCheckFailed() bodyUI->updateStack->setCurrentIndex(static_cast(updateIndex::failed)); } +void AboutForm::reloadTheme() +{ + replaceVersions(); +} + /** * @brief Creates hyperlink with specific style. * @param path The URL of the page the link goes to. diff --git a/src/widget/form/settings/aboutform.h b/src/widget/form/settings/aboutform.h index b8ce6a7ca..9a884cb34 100644 --- a/src/widget/form/settings/aboutform.h +++ b/src/widget/form/settings/aboutform.h @@ -47,6 +47,7 @@ public slots: void onUpdateAvailable(QString latestVersion, QUrl link); void onUpToDate(); void onUpdateCheckFailed(); + void reloadTheme() override; private: void retranslateUi(); diff --git a/src/widget/form/settings/genericsettings.cpp b/src/widget/form/settings/genericsettings.cpp index dcd372a9d..383059bae 100644 --- a/src/widget/form/settings/genericsettings.cpp +++ b/src/widget/form/settings/genericsettings.cpp @@ -18,6 +18,7 @@ */ #include "genericsettings.h" +#include "src/widget/gui.h" #include #include @@ -34,6 +35,7 @@ GenericForm::GenericForm(const QPixmap& icon) : formIcon(icon) { + connect(&GUI::getInstance(), &GUI::themeReload, this, &GenericForm::reloadTheme); } QPixmap GenericForm::getFormIcon() diff --git a/src/widget/form/settings/genericsettings.h b/src/widget/form/settings/genericsettings.h index ca9d15163..eeee88d5a 100644 --- a/src/widget/form/settings/genericsettings.h +++ b/src/widget/form/settings/genericsettings.h @@ -33,6 +33,9 @@ public: virtual QString getFormName() = 0; QPixmap getFormIcon(); +public slots: + virtual void reloadTheme() {} + protected: bool eventFilter(QObject* o, QEvent* e) final; void eventsInit(); diff --git a/src/widget/genericchatitemwidget.cpp b/src/widget/genericchatitemwidget.cpp index d76826b24..93ce36084 100644 --- a/src/widget/genericchatitemwidget.cpp +++ b/src/widget/genericchatitemwidget.cpp @@ -19,8 +19,8 @@ #include "genericchatitemwidget.h" #include "src/persistence/settings.h" -#include "src/widget/style.h" #include "src/widget/tool/croppinglabel.h" +#include "src/widget/gui.h" #include GenericChatItemWidget::GenericChatItemWidget(bool compact, QWidget* parent) @@ -32,6 +32,8 @@ GenericChatItemWidget::GenericChatItemWidget(bool compact, QWidget* parent) nameLabel = new CroppingLabel(this); nameLabel->setObjectName("name"); nameLabel->setTextFormat(Qt::PlainText); + + connect(&GUI::getInstance(), &GUI::themeReload, this, &GenericChatItemWidget::reloadTheme); } bool GenericChatItemWidget::isCompact() const diff --git a/src/widget/genericchatitemwidget.h b/src/widget/genericchatitemwidget.h index b5ec91709..97b871d0f 100644 --- a/src/widget/genericchatitemwidget.h +++ b/src/widget/genericchatitemwidget.h @@ -46,6 +46,9 @@ public: Q_PROPERTY(bool compact READ isCompact WRITE setCompact) +public slots: + virtual void reloadTheme() {} + protected: CroppingLabel* nameLabel; QLabel statusPic; diff --git a/src/widget/genericchatroomwidget.h b/src/widget/genericchatroomwidget.h index 81924b260..42a4c38bf 100644 --- a/src/widget/genericchatroomwidget.h +++ b/src/widget/genericchatroomwidget.h @@ -60,10 +60,9 @@ public slots: QString getStatusMsg() const; QString getTitle() const; - void reloadTheme(); - void activate(); void compactChange(bool compact); + void reloadTheme() override; signals: void chatroomWidgetClicked(GenericChatroomWidget* widget); diff --git a/src/widget/gui.cpp b/src/widget/gui.cpp index cf19aa50a..a3c5c6cc5 100644 --- a/src/widget/gui.cpp +++ b/src/widget/gui.cpp @@ -94,13 +94,16 @@ void GUI::setWindowTitle(const QString& title) /** * @brief Reloads the application theme and redraw the window. + * + * For reload theme need connect signal themeReload() to function for reload + * For example: connect(&GUI::getInstance(), &GUI::themeReload, this, &SomeClass::reloadTheme); */ void GUI::reloadTheme() { if (QThread::currentThread() == qApp->thread()) { - getInstance()._reloadTheme(); + getInstance().themeReload(); } else { - QMetaObject::invokeMethod(&getInstance(), "_reloadTheme", Qt::BlockingQueuedConnection); + QMetaObject::invokeMethod(&getInstance(), "themeReload", Qt::BlockingQueuedConnection); } } @@ -224,13 +227,6 @@ void GUI::_setWindowTitle(const QString& title) w->setWindowTitle("qTox - " + title); } -void GUI::_reloadTheme() -{ - Widget* w = Nexus::getDesktopGUI(); - if (w) - w->reloadTheme(); -} - void GUI::_showInfo(const QString& title, const QString& msg) { QMessageBox messageBox(QMessageBox::Information, title, msg, QMessageBox::Ok, getMainWidget()); diff --git a/src/widget/gui.h b/src/widget/gui.h index 929016e6e..a6ce6ee35 100644 --- a/src/widget/gui.h +++ b/src/widget/gui.h @@ -50,7 +50,6 @@ private slots: // Private implementation, those must be called from the GUI thread void _setEnabled(bool state); void _setWindowTitle(const QString& title); - void _reloadTheme(); void _showInfo(const QString& title, const QString& msg); void _showWarning(const QString& title, const QString& msg); void _showError(const QString& title, const QString& msg); @@ -58,4 +57,7 @@ private slots: bool warning = true, bool yesno = true); bool _askQuestion(const QString& title, const QString& msg, const QString& button1, const QString& button2, bool defaultAns = false, bool warning = true); + +signals: + void themeReload(); }; diff --git a/src/widget/searchform.cpp b/src/widget/searchform.cpp index e23fd63fe..d9f29482d 100644 --- a/src/widget/searchform.cpp +++ b/src/widget/searchform.cpp @@ -19,6 +19,7 @@ #include "searchform.h" #include "form/searchsettingsform.h" +#include "src/widget/gui.h" #include "src/widget/style.h" #include @@ -91,6 +92,8 @@ SearchForm::SearchForm(QWidget* parent) : QWidget(parent) connect(settingsButton, &QPushButton::clicked, this, &SearchForm::clickedSearch); connect(settings, &SearchSettingsForm::updateSettings, this, &SearchForm::changedState); + + connect(&GUI::getInstance(), &GUI::themeReload, this, &SearchForm::reloadTheme); } void SearchForm::removeSearchPhrase() diff --git a/src/widget/searchform.h b/src/widget/searchform.h index cd13bea09..04d72dae2 100644 --- a/src/widget/searchform.h +++ b/src/widget/searchform.h @@ -44,7 +44,6 @@ public: ParameterSearch getParameterSearch(); void setFocusEditor(); void insertEditor(const QString &text); - void reloadTheme(); protected: void showEvent(QShowEvent* event) final; @@ -84,6 +83,7 @@ private slots: public slots: void showMessageNotFound(SearchDirection direction); + void reloadTheme(); signals: void searchInBegin(const QString& phrase, const ParameterSearch& parameter); diff --git a/src/widget/tool/activatedialog.cpp b/src/widget/tool/activatedialog.cpp index 433991f49..2af70b086 100644 --- a/src/widget/tool/activatedialog.cpp +++ b/src/widget/tool/activatedialog.cpp @@ -19,11 +19,13 @@ #include "activatedialog.h" +#include "src/widget/gui.h" #include ActivateDialog::ActivateDialog(QWidget* parent, Qt::WindowFlags f) : QDialog(parent, f) { + connect(&GUI::getInstance(), &GUI::themeReload, this, &ActivateDialog::reloadTheme); } bool ActivateDialog::event(QEvent* event) diff --git a/src/widget/tool/activatedialog.h b/src/widget/tool/activatedialog.h index 7aacc9355..52a43ebd8 100644 --- a/src/widget/tool/activatedialog.h +++ b/src/widget/tool/activatedialog.h @@ -32,6 +32,9 @@ public: #endif bool event(QEvent* event) override; +public slots: + virtual void reloadTheme() {} + signals: void windowStateChanged(Qt::WindowStates state); }; diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index 673b10092..a95fe9308 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -463,6 +463,8 @@ void Widget::init() connect(&settings, &Settings::groupchatPositionChanged, contactListWidget, &FriendListWidget::onGroupchatPositionChanged); + connect(&GUI::getInstance(), &GUI::themeReload, this, &Widget::reloadTheme); + reloadTheme(); updateIcons(); retranslateUi(); @@ -1825,7 +1827,7 @@ ContentLayout* Widget::createContentDialog(DialogType type) const Translator::registerHandler(std::bind(&Dialog::retranslateUi, this), this); retranslateUi(); setWindowIcon(QIcon(":/img/icons/qtox.svg")); - setStyleSheet(Style::getStylesheet("window/general.css")); + reloadTheme(); connect(core, &Core::usernameSet, this, &Dialog::retranslateUi); } @@ -1842,6 +1844,11 @@ ContentLayout* Widget::createContentDialog(DialogType type) const setWindowTitle(core->getUsername() + QStringLiteral(" - ") + Widget::fromDialogType(type)); } + void reloadTheme() final + { + setStyleSheet(Style::getStylesheet("window/general.css")); + } + protected: void resizeEvent(QResizeEvent* event) override { @@ -2394,6 +2401,12 @@ void Widget::clearAllReceipts() void Widget::reloadTheme() { + setStyleSheet(""); + QWidgetList wgts = findChildren(); + for (auto x : wgts) { + x->setStyleSheet(""); + } + this->setStyleSheet(Style::getStylesheet("window/general.css")); QString statusPanelStyle = Style::getStylesheet("window/statusPanel.css"); ui->tooliconsZone->setStyleSheet(Style::getStylesheet("tooliconsZone/tooliconsZone.css")); @@ -2404,27 +2417,6 @@ void Widget::reloadTheme() contactListWidget->reDraw(); profilePicture->setStyleSheet(Style::getStylesheet("window/profile.css")); - - if (contentLayout != nullptr) { - contentLayout->reloadTheme(); - } - - for (Friend* f : FriendList::getAllFriends()) { - friendWidgets[f->getPublicKey()]->reloadTheme(); - } - - for (Group* g : GroupList::getAllGroups()) { - groupWidgets[g->getPersistentId()]->reloadTheme(); - } - - - for (auto f : FriendList::getAllFriends()) { - chatForms[f->getPublicKey()]->reloadTheme(); - } - - for (auto g : GroupList::getAllGroups()) { - groupChatForms[g->getPersistentId()]->reloadTheme(); - } } void Widget::nextContact() diff --git a/src/widget/widget.h b/src/widget/widget.h index 482889a3b..ed6184b35 100644 --- a/src/widget/widget.h +++ b/src/widget/widget.h @@ -142,7 +142,6 @@ public: void clearAllReceipts(); - void reloadTheme(); static inline QIcon prepareIcon(QString path, int w = 0, int h = 0); bool groupsVisible() const; @@ -150,6 +149,7 @@ public: void resetIcon(); public slots: + void reloadTheme(); void onShowSettings(); void onSeparateWindowClicked(bool separate); void onSeparateWindowChanged(bool separate, bool clicked);