mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-09-02 15:35:51 +00:00
Start cloud langpack support.
Change the way langpacks are stored. Support custom langpacks in the new storage.
This commit is contained in:
@@ -27,7 +27,7 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||
#include "boxes/confirm_box.h"
|
||||
#include "mainwidget.h"
|
||||
#include "mainwindow.h"
|
||||
#include "lang/lang_file_parser.h"
|
||||
#include "lang/lang_instance.h"
|
||||
#include "styles/style_boxes.h"
|
||||
|
||||
void LanguageBox::prepare() {
|
||||
@@ -35,75 +35,74 @@ void LanguageBox::prepare() {
|
||||
|
||||
setTitle(lang(lng_languages));
|
||||
|
||||
auto haveTestLang = (cLang() == languageTest);
|
||||
|
||||
_langGroup = std::make_shared<Ui::RadiobuttonGroup>(cLang());
|
||||
auto y = st::boxOptionListPadding.top();
|
||||
_langs.reserve(languageCount + (haveTestLang ? 1 : 0));
|
||||
if (haveTestLang) {
|
||||
_langs.emplace_back(this, _langGroup, languageTest, qsl("Custom Lang"), st::langsButton);
|
||||
_langs.back()->move(st::boxPadding.left() + st::boxOptionListPadding.left(), y);
|
||||
y += _langs.back()->heightNoMargins() + st::boxOptionListSkip;
|
||||
}
|
||||
for (auto i = 0; i != languageCount; ++i) {
|
||||
Lang::FileParser::Result result;
|
||||
if (i) {
|
||||
Lang::FileParser loader(qsl(":/langs/lang_") + LanguageCodes[i].c_str() + qsl(".strings"), { lng_language_name });
|
||||
result = loader.found();
|
||||
} else {
|
||||
result.insert(lng_language_name, langOriginal(lng_language_name));
|
||||
}
|
||||
_langs.emplace_back(this, _langGroup, i, result.value(lng_language_name, LanguageCodes[i].c_str() + qsl(" language")), st::langsButton);
|
||||
_langs.back()->move(st::boxPadding.left() + st::boxOptionListPadding.left(), y);
|
||||
y += _langs.back()->heightNoMargins() + st::boxOptionListSkip;
|
||||
}
|
||||
_langGroup->setChangedCallback([this](int value) { languageChanged(value); });
|
||||
|
||||
auto optionsCount = languageCount + (haveTestLang ? 1 : 0);
|
||||
setDimensions(st::langsWidth, st::boxOptionListPadding.top() + optionsCount * st::langsButton.height + (optionsCount - 1) * st::boxOptionListSkip + st::boxOptionListPadding.bottom() + st::boxPadding.bottom());
|
||||
}
|
||||
|
||||
void LanguageBox::mousePressEvent(QMouseEvent *e) {
|
||||
if ((e->modifiers() & Qt::CTRL) && (e->modifiers() & Qt::ALT) && (e->modifiers() & Qt::SHIFT)) {
|
||||
for (int32 i = 1; i < languageCount; ++i) {
|
||||
Lang::FileParser loader(qsl(":/langs/lang_") + LanguageCodes[i].c_str() + qsl(".strings"), { kLangKeysCount });
|
||||
if (!loader.errors().isEmpty()) {
|
||||
Ui::show(Box<InformBox>(qsl("Lang \"") + LanguageCodes[i].c_str() + qsl("\" error :(\n\nError: ") + loader.errors()));
|
||||
return;
|
||||
} else if (!loader.warnings().isEmpty()) {
|
||||
auto warn = loader.warnings();
|
||||
if (warn.size() > 256) warn = warn.mid(0, 253) + qsl("...");
|
||||
Ui::show(Box<InformBox>(qsl("Lang \"") + LanguageCodes[i].c_str() + qsl("\" warnings :(\n\nWarnings: ") + warn));
|
||||
return;
|
||||
request(MTPlangpack_GetLanguages()).done([this](const MTPVector<MTPLangPackLanguage> &result) {
|
||||
auto currentId = Lang::Current().id();
|
||||
auto currentFound = false;
|
||||
std::vector<QString> languageIds = { qsl("en") };
|
||||
std::vector<QString> languageNames = { qsl("English") };
|
||||
for (auto &language : result.v) {
|
||||
t_assert(language.type() == mtpc_langPackLanguage);
|
||||
auto &data = language.c_langPackLanguage();
|
||||
auto languageId = qs(data.vlang_code);
|
||||
auto languageName = qs(data.vname);
|
||||
if (languageId != qstr("en")) {
|
||||
languageIds.push_back(languageId);
|
||||
languageNames.push_back(languageName);
|
||||
}
|
||||
}
|
||||
Ui::show(Box<InformBox>(qsl("Everything seems great in all %1 languages!").arg(languageCount - 1)));
|
||||
}
|
||||
if (currentId == qstr("custom")) {
|
||||
languageIds.insert(languageIds.begin(), currentId);
|
||||
languageNames.insert(languageNames.begin(), qsl("Custom LangPack"));
|
||||
currentFound = true;
|
||||
}
|
||||
|
||||
auto languageCount = languageIds.size();
|
||||
_langGroup = std::make_shared<Ui::RadiobuttonGroup>(cLang());
|
||||
auto y = st::boxOptionListPadding.top();
|
||||
_langs.reserve(languageCount);
|
||||
for (auto i = 0; i != languageCount; ++i) {
|
||||
if (!currentFound && languageIds[i] == currentId) {
|
||||
currentFound = true;
|
||||
}
|
||||
_langs.emplace_back(this, _langGroup, i, languageNames[i], st::langsButton);
|
||||
auto button = _langs.back().data();
|
||||
button->moveToLeft(st::boxPadding.left() + st::boxOptionListPadding.left(), y + st::langsButton.margin.top());
|
||||
button->show();
|
||||
y += button->heightNoMargins() + st::boxOptionListSkip;
|
||||
}
|
||||
_langGroup->setChangedCallback([this](int value) { languageChanged(value); });
|
||||
|
||||
setDimensions(st::langsWidth, st::boxOptionListPadding.top() + languageCount * st::langsButton.height + languageCount * st::boxOptionListSkip + st::boxOptionListPadding.bottom() + st::boxPadding.bottom());
|
||||
}).fail([this](const RPCError &error) {
|
||||
closeBox();
|
||||
}).send();
|
||||
|
||||
setDimensions(st::langsWidth, st::langsWidth);
|
||||
}
|
||||
|
||||
void LanguageBox::languageChanged(int languageId) {
|
||||
Expects(languageId == languageTest || (languageId >= 0 && languageId < base::array_size(LanguageCodes)));
|
||||
//Expects(languageId == languageTest || (languageId >= 0 && languageId < base::array_size(LanguageCodes)));
|
||||
|
||||
if (languageId == cLang()) {
|
||||
return;
|
||||
}
|
||||
//if (languageId == cLang()) {
|
||||
// return;
|
||||
//}
|
||||
|
||||
Lang::FileParser::Result result;
|
||||
if (languageId > 0) {
|
||||
Lang::FileParser loader(qsl(":/langs/lang_") + LanguageCodes[languageId].c_str() + qsl(".strings"), { lng_sure_save_language, lng_cancel, lng_box_ok });
|
||||
result = loader.found();
|
||||
} else if (languageId == languageTest) {
|
||||
Lang::FileParser loader(cLangFile(), { lng_sure_save_language, lng_cancel, lng_box_ok });
|
||||
result = loader.found();
|
||||
}
|
||||
auto text = result.value(lng_sure_save_language, langOriginal(lng_sure_save_language)),
|
||||
save = result.value(lng_box_ok, langOriginal(lng_box_ok)),
|
||||
cancel = result.value(lng_cancel, langOriginal(lng_cancel));
|
||||
Ui::show(Box<ConfirmBox>(text, save, cancel, base::lambda_guarded(this, [this, languageId] {
|
||||
cSetLang(languageId);
|
||||
Local::writeSettings();
|
||||
App::restart();
|
||||
}), base::lambda_guarded(this, [this] {
|
||||
_langGroup->setValue(cLang());
|
||||
})), KeepOtherLayers);
|
||||
//Lang::FileParser::Result result;
|
||||
//if (languageId > 0) {
|
||||
// Lang::FileParser loader(qsl(":/langs/lang_") + LanguageCodes[languageId].c_str() + qsl(".strings"), { lng_sure_save_language, lng_cancel, lng_box_ok });
|
||||
// result = loader.found();
|
||||
//} else if (languageId == languageTest) {
|
||||
// Lang::FileParser loader(cLangFile(), { lng_sure_save_language, lng_cancel, lng_box_ok });
|
||||
// result = loader.found();
|
||||
//}
|
||||
//auto text = result.value(lng_sure_save_language, Lang::GetOriginalValue(lng_sure_save_language)),
|
||||
// save = result.value(lng_box_ok, Lang::GetOriginalValue(lng_box_ok)),
|
||||
// cancel = result.value(lng_cancel, Lang::GetOriginalValue(lng_cancel));
|
||||
//Ui::show(Box<ConfirmBox>(text, save, cancel, base::lambda_guarded(this, [this, languageId] {
|
||||
// cSetLang(languageId);
|
||||
// Local::writeSettings();
|
||||
// App::restart();
|
||||
//}), base::lambda_guarded(this, [this] {
|
||||
// _langGroup->setValue(cLang());
|
||||
//})), KeepOtherLayers);
|
||||
}
|
||||
|
Reference in New Issue
Block a user