From 6527fd4fca271b3787050ab6af6319c0c9896de8 Mon Sep 17 00:00:00 2001 From: powerjungle Date: Sun, 22 Nov 2020 16:27:09 +0200 Subject: [PATCH] fix(ui): system translation not being updated This commit fixes an issue when switching from any language back to English, the system translations remain to be the last language even if the application translations have switched back to English. --- src/widget/translator.cpp | 28 ++++++++++++++++++---------- src/widget/translator.h | 3 ++- 2 files changed, 20 insertions(+), 11 deletions(-) diff --git a/src/widget/translator.cpp b/src/widget/translator.cpp index 6c0da8763..78c8719b3 100644 --- a/src/widget/translator.cpp +++ b/src/widget/translator.cpp @@ -28,7 +28,8 @@ #include #include -QTranslator* Translator::translator{nullptr}; +QTranslator* Translator::core_translator{nullptr}; +QTranslator* Translator::app_translator{nullptr}; QVector Translator::callbacks; QMutex Translator::lock; @@ -39,31 +40,38 @@ void Translator::translate(const QString& localeName) { QMutexLocker locker{&lock}; - if (!translator) - translator = new QTranslator(); + if (!core_translator) + core_translator = new QTranslator(); + + if (!app_translator) + app_translator = new QTranslator(); + + // Remove old translations + QCoreApplication::removeTranslator(core_translator); + QApplication::removeTranslator(app_translator); // Load translations - QCoreApplication::removeTranslator(translator); QString locale = localeName.isEmpty() ? QLocale::system().name().section('_', 0, 0) : localeName; if (locale != "en") { - if (translator->load(locale, ":translations/")) { + if (core_translator->load(locale, ":translations/")) { qDebug() << "Loaded translation" << locale; - // system menu translation - QTranslator* qtTranslator = new QTranslator(); + // System menu translation QString s_locale = "qt_" + locale; QString location = QLibraryInfo::location(QLibraryInfo::TranslationsPath); - if (qtTranslator->load(s_locale, location)) { - QApplication::installTranslator(qtTranslator); + if (app_translator->load(s_locale, location)) { + QApplication::installTranslator(app_translator); qDebug() << "System translation loaded" << locale; } else { qDebug() << "System translation not loaded" << locale; } + + // Application translation + QCoreApplication::installTranslator(core_translator); } else { qDebug() << "Error loading translation" << locale; } - QCoreApplication::installTranslator(translator); } // After the language is changed from RTL to LTR, the layout direction isn't diff --git a/src/widget/translator.h b/src/widget/translator.h index a23e15e50..eb6e43c37 100644 --- a/src/widget/translator.h +++ b/src/widget/translator.h @@ -38,5 +38,6 @@ private: using Callback = QPair>; static QVector callbacks; static QMutex lock; - static QTranslator* translator; + static QTranslator* core_translator; + static QTranslator* app_translator; };