added i18n for v4
This commit is contained in:
parent
1a8c08799f
commit
68095700a2
7 changed files with 3729 additions and 1974 deletions
|
|
@ -50,10 +50,30 @@ endif()
|
||||||
|
|
||||||
qt6_add_resources(QRC ${QRC} ${CMAKE_CURRENT_LIST_DIR}/resources.qrc)
|
qt6_add_resources(QRC ${QRC} ${CMAKE_CURRENT_LIST_DIR}/resources.qrc)
|
||||||
|
|
||||||
qt6_add_translations(${PROJECT} TS_FILES
|
set(AMNEZIAVPN_TR_FILES
|
||||||
${CMAKE_CURRENT_LIST_DIR}/translations/amneziavpn_ru.ts
|
${CMAKE_CURRENT_LIST_DIR}/translations/amneziavpn_ru.ts
|
||||||
|
${CMAKE_CURRENT_LIST_DIR}/translations/amneziavpn_zh_CN.ts
|
||||||
)
|
)
|
||||||
|
|
||||||
|
file(GLOB_RECURSE AMNEZIAVPN_TR_SOURCES *.qrc *.cpp *.h *.ui)
|
||||||
|
if ( BUILD_TRANSLATIONS )
|
||||||
|
qt_create_translation(AMNEZIAVPN_MESSAGES ${AMNEZIAVPN_TR_SOURCES} ${AMNEZIAVPN_TR_FILES})
|
||||||
|
qt_add_translation(AMNEZIAVPN_QM_FILES ${AMNEZIAVPN_TR_FILES})
|
||||||
|
add_custom_target(amnezia_messages DEPENDS ${AMNEZIAVPN_MESSAGES})
|
||||||
|
add_custom_target(amnezia_translations DEPENDS ${AMNEZIAVPN_QM_FILES} amnezia_messages)
|
||||||
|
add_dependencies(${PROJECT} amnezia_translations)
|
||||||
|
|
||||||
|
if (BUILD_TRANSLATIONS_AS_RESOURCES)
|
||||||
|
set(QM_FILE_LIST "")
|
||||||
|
foreach(FILE ${AMNEZIAVPN_QM_FILES})
|
||||||
|
list(APPEND QM_FILE_LIST "<file>${FILE}</file>")
|
||||||
|
endforeach()
|
||||||
|
string(REPLACE ";" "" QM_FILE_LIST ${QM_FILE_LIST})
|
||||||
|
configure_file(${CMAKE_CURRENT_LIST_DIR}/translations/translations.qrc ${CMAKE_CURRENT_LIST_DIR}/translations.qrc)
|
||||||
|
target_sources(${PROJECT} PRIVATE ${CMAKE_CURRENT_LIST_DIR}/translations.qrc)
|
||||||
|
endif()
|
||||||
|
endif( BUILD_TRANSLATIONS )
|
||||||
|
|
||||||
if(IOS)
|
if(IOS)
|
||||||
#execute_process(COMMAND bash ${CMAKE_CURRENT_LIST_DIR}/scripts/run-build-cloak.sh)
|
#execute_process(COMMAND bash ${CMAKE_CURRENT_LIST_DIR}/scripts/run-build-cloak.sh)
|
||||||
execute_process(COMMAND bash ${CMAKE_CURRENT_LIST_DIR}/ios/scripts/openvpn.sh args
|
execute_process(COMMAND bash ${CMAKE_CURRENT_LIST_DIR}/ios/scripts/openvpn.sh args
|
||||||
|
|
|
||||||
|
|
@ -221,27 +221,21 @@ void AmneziaApplication::loadTranslator()
|
||||||
{
|
{
|
||||||
auto locale = m_settings->getAppLanguage();
|
auto locale = m_settings->getAppLanguage();
|
||||||
m_translator.reset(new QTranslator());
|
m_translator.reset(new QTranslator());
|
||||||
if (locale != QLocale::English) {
|
updateTranslator(locale);
|
||||||
if (m_translator->load(locale, QString("amneziavpn"), QLatin1String("_"), QLatin1String(":/i18n"))) {
|
|
||||||
if (QCoreApplication::installTranslator(m_translator.get())) {
|
|
||||||
m_settings->setAppLanguage(locale);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void AmneziaApplication::updateTranslator(const QLocale &locale)
|
void AmneziaApplication::updateTranslator(const QLocale &locale)
|
||||||
{
|
{
|
||||||
QResource::registerResource(":/translations.qrc");
|
QResource::registerResource(":/translations.qrc");
|
||||||
if (!m_translator->isEmpty())
|
if (!m_translator->isEmpty()) {
|
||||||
QCoreApplication::removeTranslator(m_translator.get());
|
QCoreApplication::removeTranslator(m_translator.get());
|
||||||
|
|
||||||
if (locale == QLocale::English) {
|
|
||||||
m_settings->setAppLanguage(locale);
|
|
||||||
m_engine->retranslate();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_translator->load(locale, QString("amneziavpn"), QLatin1String("_"), QLatin1String(":/i18n"))) {
|
m_settings->setAppLanguage(locale);
|
||||||
|
|
||||||
|
QString strFileName = QString("amneziavpn")+QLatin1String("_")+locale.name()+".qm";
|
||||||
|
if (m_translator->load(strFileName, "../../../")) {
|
||||||
if (QCoreApplication::installTranslator(m_translator.get())) {
|
if (QCoreApplication::installTranslator(m_translator.get())) {
|
||||||
m_settings->setAppLanguage(locale);
|
m_settings->setAppLanguage(locale);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -53,13 +53,13 @@ int main(int argc, char *argv[])
|
||||||
app.setOrganizationName(ORGANIZATION_NAME);
|
app.setOrganizationName(ORGANIZATION_NAME);
|
||||||
app.setApplicationDisplayName(APPLICATION_NAME);
|
app.setApplicationDisplayName(APPLICATION_NAME);
|
||||||
|
|
||||||
app.loadTranslator();
|
|
||||||
app.loadFonts();
|
app.loadFonts();
|
||||||
|
|
||||||
bool doExec = app.parseCommands();
|
bool doExec = app.parseCommands();
|
||||||
|
|
||||||
if (doExec) {
|
if (doExec) {
|
||||||
app.init();
|
app.init();
|
||||||
|
app.loadTranslator();
|
||||||
|
|
||||||
qInfo().noquote() << QString("Started %1 version %2").arg(APPLICATION_NAME, APP_VERSION);
|
qInfo().noquote() << QString("Started %1 version %2").arg(APPLICATION_NAME, APP_VERSION);
|
||||||
qInfo().noquote() << QString("%1 (%2)").arg(QSysInfo::prettyProductName(), QSysInfo::currentCpuArchitecture());
|
qInfo().noquote() << QString("%1 (%2)").arg(QSysInfo::prettyProductName(), QSysInfo::currentCpuArchitecture());
|
||||||
|
|
|
||||||
File diff suppressed because it is too large
Load diff
2666
client/translations/amneziavpn_zh_CN.ts
Normal file
2666
client/translations/amneziavpn_zh_CN.ts
Normal file
File diff suppressed because it is too large
Load diff
|
|
@ -6,7 +6,8 @@ LanguageModel::LanguageModel(std::shared_ptr<Settings> settings, QObject *parent
|
||||||
QMetaEnum metaEnum = QMetaEnum::fromType<LanguageSettings::AvailableLanguageEnum>();
|
QMetaEnum metaEnum = QMetaEnum::fromType<LanguageSettings::AvailableLanguageEnum>();
|
||||||
for (int i = 0; i < metaEnum.keyCount(); i++) {
|
for (int i = 0; i < metaEnum.keyCount(); i++) {
|
||||||
m_availableLanguages.push_back(
|
m_availableLanguages.push_back(
|
||||||
LanguageModelData { metaEnum.valueToKey(i), static_cast<LanguageSettings::AvailableLanguageEnum>(i) });
|
LanguageModelData {getLocalLanguageName(static_cast<LanguageSettings::AvailableLanguageEnum>(i)),
|
||||||
|
static_cast<LanguageSettings::AvailableLanguageEnum>(i) });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -36,11 +37,26 @@ QHash<int, QByteArray> LanguageModel::roleNames() const
|
||||||
return roles;
|
return roles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString LanguageModel::getLocalLanguageName(const LanguageSettings::AvailableLanguageEnum language)
|
||||||
|
{
|
||||||
|
QString strLanguage("");
|
||||||
|
switch (language) {
|
||||||
|
case LanguageSettings::AvailableLanguageEnum::English: strLanguage = "English"; break;
|
||||||
|
case LanguageSettings::AvailableLanguageEnum::Russian: strLanguage = "Русский"; break;
|
||||||
|
case LanguageSettings::AvailableLanguageEnum::China_cn: strLanguage = "\347\256\200\344\275\223\344\270\255\346\226\207"; break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return strLanguage;
|
||||||
|
}
|
||||||
|
|
||||||
void LanguageModel::changeLanguage(const LanguageSettings::AvailableLanguageEnum language)
|
void LanguageModel::changeLanguage(const LanguageSettings::AvailableLanguageEnum language)
|
||||||
{
|
{
|
||||||
switch (language) {
|
switch (language) {
|
||||||
case LanguageSettings::AvailableLanguageEnum::English: emit updateTranslations(QLocale::English); break;
|
case LanguageSettings::AvailableLanguageEnum::English: emit updateTranslations(QLocale::English); break;
|
||||||
case LanguageSettings::AvailableLanguageEnum::Russian: emit updateTranslations(QLocale::Russian); break;
|
case LanguageSettings::AvailableLanguageEnum::Russian: emit updateTranslations(QLocale::Russian); break;
|
||||||
|
case LanguageSettings::AvailableLanguageEnum::China_cn: emit updateTranslations(QLocale::Chinese); break;
|
||||||
default: emit updateTranslations(QLocale::English); break;
|
default: emit updateTranslations(QLocale::English); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -51,6 +67,7 @@ int LanguageModel::getCurrentLanguageIndex()
|
||||||
switch (locale.language()) {
|
switch (locale.language()) {
|
||||||
case QLocale::English: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::English); break;
|
case QLocale::English: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::English); break;
|
||||||
case QLocale::Russian: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::Russian); break;
|
case QLocale::Russian: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::Russian); break;
|
||||||
|
case QLocale::Chinese: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::China_cn); break;
|
||||||
default: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::English); break;
|
default: return static_cast<int>(LanguageSettings::AvailableLanguageEnum::English); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,8 @@ namespace LanguageSettings
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum class AvailableLanguageEnum {
|
enum class AvailableLanguageEnum {
|
||||||
English,
|
English,
|
||||||
Russian
|
Russian,
|
||||||
|
China_cn
|
||||||
};
|
};
|
||||||
Q_ENUM_NS(AvailableLanguageEnum)
|
Q_ENUM_NS(AvailableLanguageEnum)
|
||||||
|
|
||||||
|
|
@ -59,6 +60,8 @@ protected:
|
||||||
QHash<int, QByteArray> roleNames() const override;
|
QHash<int, QByteArray> roleNames() const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
QString getLocalLanguageName(const LanguageSettings::AvailableLanguageEnum language);
|
||||||
|
|
||||||
QVector<LanguageModelData> m_availableLanguages;
|
QVector<LanguageModelData> m_availableLanguages;
|
||||||
|
|
||||||
std::shared_ptr<Settings> m_settings;
|
std::shared_ptr<Settings> m_settings;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue