mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Improvement of selection of language / dictionaries.
When switching the languages, if the newly selected dictionary is "compatible" with the system best language or user's locale, then the system best language locale or user's locale is activated, not the locale connected to the dictionary.
This commit is contained in:
parent
ace275af7f
commit
78697b2acf
2 changed files with 38 additions and 22 deletions
|
@ -640,12 +640,21 @@ bool GUI_App::select_language()
|
||||||
|
|
||||||
const long index = wxGetSingleChoiceIndex(_(L("Select the language")), _(L("Language")), names, init_selection_default);
|
const long index = wxGetSingleChoiceIndex(_(L("Select the language")), _(L("Language")), names, init_selection_default);
|
||||||
// Try to load a new language.
|
// Try to load a new language.
|
||||||
if (index != -1 && (init_selection == -1 || init_selection != index) && this->load_language(language_infos[index]->CanonicalName, false)) {
|
if (index != -1 && (init_selection == -1 || init_selection != index)) {
|
||||||
|
const wxLanguageInfo *new_language_info = language_infos[index];
|
||||||
|
if (new_language_info == m_language_info_best || new_language_info == m_language_info_system) {
|
||||||
|
// The newly selected profile matches user's default profile exactly. That's great.
|
||||||
|
} else if (m_language_info_best != nullptr && new_language_info->CanonicalName.BeforeFirst('_') == m_language_info_best->CanonicalName.BeforeFirst('_'))
|
||||||
|
new_language_info = m_language_info_best;
|
||||||
|
else if (m_language_info_system != nullptr && new_language_info->CanonicalName.BeforeFirst('_') == m_language_info_system->CanonicalName.BeforeFirst('_'))
|
||||||
|
new_language_info = m_language_info_system;
|
||||||
|
if (this->load_language(new_language_info->CanonicalName, false)) {
|
||||||
// Save language at application config.
|
// Save language at application config.
|
||||||
app_config->set("translation_language", m_wxLocale->GetCanonicalName().ToUTF8().data());
|
app_config->set("translation_language", m_wxLocale->GetCanonicalName().ToUTF8().data());
|
||||||
app_config->save();
|
app_config->save();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -659,19 +668,11 @@ bool GUI_App::load_language(wxString language, bool initial)
|
||||||
wxFileTranslationsLoader::AddCatalogLookupPathPrefix(from_u8(localization_dir()));
|
wxFileTranslationsLoader::AddCatalogLookupPathPrefix(from_u8(localization_dir()));
|
||||||
// Get the active language from PrusaSlicer.ini, or empty string if the key does not exist.
|
// Get the active language from PrusaSlicer.ini, or empty string if the key does not exist.
|
||||||
language = app_config->get("translation_language");
|
language = app_config->get("translation_language");
|
||||||
}
|
// Get the system language.
|
||||||
|
{
|
||||||
const wxLanguageInfo *language_info = wxLocale::FindLanguageInfo(language);
|
|
||||||
if (language_info == nullptr)
|
|
||||||
language.clear();
|
|
||||||
|
|
||||||
if (language.IsEmpty()) {
|
|
||||||
const wxLanguage lang_system = wxLanguage(wxLocale::GetSystemLanguage());
|
const wxLanguage lang_system = wxLanguage(wxLocale::GetSystemLanguage());
|
||||||
const wxLanguageInfo *lang_info_system = nullptr;
|
if (lang_system != wxLANGUAGE_UNKNOWN)
|
||||||
if (lang_system != wxLANGUAGE_UNKNOWN) {
|
m_language_info_system = wxLocale::GetLanguageInfo(lang_system);
|
||||||
lang_info_system = wxLocale::GetLanguageInfo(lang_system);
|
|
||||||
if (lang_info_system != nullptr)
|
|
||||||
language = lang_info_system->CanonicalName;
|
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
// Allocating a temporary locale will switch the default wxTranslations to its internal wxTranslations instance.
|
// Allocating a temporary locale will switch the default wxTranslations to its internal wxTranslations instance.
|
||||||
|
@ -685,8 +686,19 @@ bool GUI_App::load_language(wxString language, bool initial)
|
||||||
// for not having the English dictionary. Let's hope wxWidgets of various versions process this call the same way.
|
// for not having the English dictionary. Let's hope wxWidgets of various versions process this call the same way.
|
||||||
wxString best_language = wxTranslations::Get()->GetBestTranslation(SLIC3R_APP_KEY, wxLANGUAGE_ENGLISH);
|
wxString best_language = wxTranslations::Get()->GetBestTranslation(SLIC3R_APP_KEY, wxLANGUAGE_ENGLISH);
|
||||||
if (! best_language.IsEmpty())
|
if (! best_language.IsEmpty())
|
||||||
language = best_language;
|
m_language_info_best = wxLocale::FindLanguageInfo(best_language);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const wxLanguageInfo *language_info = wxLocale::FindLanguageInfo(language);
|
||||||
|
if (language_info == nullptr)
|
||||||
|
language.clear();
|
||||||
|
|
||||||
|
if (language.IsEmpty()) {
|
||||||
|
if (m_language_info_system != nullptr && m_language_info_system->LayoutDirection != wxLayout_RightToLeft)
|
||||||
|
language = m_language_info_system->CanonicalName;
|
||||||
|
if (m_language_info_best != nullptr && m_language_info_best->LayoutDirection != wxLayout_RightToLeft)
|
||||||
|
language = m_language_info_best->CanonicalName;
|
||||||
if (language.IsEmpty())
|
if (language.IsEmpty())
|
||||||
language = "en_US";
|
language = "en_US";
|
||||||
}
|
}
|
||||||
|
@ -721,7 +733,7 @@ bool GUI_App::load_language(wxString language, bool initial)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Release the old locales, create new locales.
|
// Release the old locales, create new locales.
|
||||||
|
//FIXME wxWidgets cause havoc if the current locale is deleted. We just forget it causing memory leaks for now.
|
||||||
m_wxLocale.release();
|
m_wxLocale.release();
|
||||||
m_wxLocale = Slic3r::make_unique<wxLocale>();
|
m_wxLocale = Slic3r::make_unique<wxLocale>();
|
||||||
m_wxLocale->Init(language_info->Language);
|
m_wxLocale->Init(language_info->Language);
|
||||||
|
|
|
@ -89,6 +89,10 @@ class GUI_App : public wxApp
|
||||||
// Note: for 100% Scale m_em_unit = 10 -> it's a good enough coefficient for a size setting of controls
|
// Note: for 100% Scale m_em_unit = 10 -> it's a good enough coefficient for a size setting of controls
|
||||||
|
|
||||||
std::unique_ptr<wxLocale> m_wxLocale;
|
std::unique_ptr<wxLocale> m_wxLocale;
|
||||||
|
// System language, from locales, owned by wxWidgets.
|
||||||
|
const wxLanguageInfo *m_language_info_system = nullptr;
|
||||||
|
// Best translation language, provided by Windows or OSX, owned by wxWidgets.
|
||||||
|
const wxLanguageInfo *m_language_info_best = nullptr;
|
||||||
|
|
||||||
std::unique_ptr<ImGuiWrapper> m_imgui;
|
std::unique_ptr<ImGuiWrapper> m_imgui;
|
||||||
std::unique_ptr<PrintHostJobQueue> m_printhost_job_queue;
|
std::unique_ptr<PrintHostJobQueue> m_printhost_job_queue;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue