fix: try to fix the language pack issue

This commit is contained in:
huzibaca 2025-01-12 22:22:06 +08:00
parent 146a66fb09
commit d2f51ce509
3 changed files with 20 additions and 36 deletions

View File

@ -249,8 +249,10 @@ pub async fn patch_verge(patch: IVerge) -> Result<()> {
should_update_sysproxy = true; should_update_sysproxy = true;
} }
if language.is_some() if language.is_some() {
|| common_tray_icon.is_some() should_update_systray_menu = true;
}
if common_tray_icon.is_some()
|| sysproxy_tray_icon.is_some() || sysproxy_tray_icon.is_some()
|| tun_tray_icon.is_some() || tun_tray_icon.is_some()
|| tray_icon.is_some() || tray_icon.is_some()

View File

@ -6,37 +6,19 @@ use sys_locale;
pub fn get_supported_languages() -> Vec<String> { pub fn get_supported_languages() -> Vec<String> {
let project_dir = Path::new(env!("CARGO_MANIFEST_DIR")).parent().unwrap(); let project_dir = Path::new(env!("CARGO_MANIFEST_DIR")).parent().unwrap();
let i18n_path = project_dir.join("src/services/i18n.ts"); let locales_dir = project_dir.join("src/locales");
let mut languages = Vec::new();
if let Ok(content) = fs::read_to_string(i18n_path) { if let Ok(entries) = fs::read_dir(locales_dir) {
let mut languages = Vec::new(); for entry in entries.flatten() {
for line in content.lines() { if let Some(file_name) = entry.file_name().to_str() {
if line.contains("resources = {") { if let Some(lang) = file_name.strip_suffix(".json") {
for line in content.lines() { languages.push(lang.to_string());
if let Some(lang) = line.trim().strip_suffix(": { translation:") {
let lang = lang.trim().trim_matches('"');
if !lang.is_empty() {
languages.push(lang.to_string());
}
}
if line.contains("};") {
break;
}
} }
break;
} }
} }
if !languages.is_empty() {
return languages;
}
} }
languages
vec![
"en".to_string(),
"ru".to_string(),
"zh".to_string(),
"fa".to_string(),
]
} }
static TRANSLATIONS: Lazy<HashMap<String, Value>> = Lazy::new(|| { static TRANSLATIONS: Lazy<HashMap<String, Value>> = Lazy::new(|| {
@ -44,7 +26,7 @@ static TRANSLATIONS: Lazy<HashMap<String, Value>> = Lazy::new(|| {
let locales_dir = project_dir.join("src/locales"); let locales_dir = project_dir.join("src/locales");
let mut translations = HashMap::new(); let mut translations = HashMap::new();
for lang in ["en", "ru", "zh", "fa", "tt"] { for lang in get_supported_languages() {
let file_path = locales_dir.join(format!("{}.json", lang)); let file_path = locales_dir.join(format!("{}.json", lang));
if let Ok(content) = fs::read_to_string(file_path) { if let Ok(content) = fs::read_to_string(file_path) {
if let Ok(json) = serde_json::from_str(&content) { if let Ok(json) = serde_json::from_str(&content) {
@ -71,8 +53,8 @@ pub fn t(key: &str) -> String {
} }
} }
// Fallback to English // Fallback to Chinese
if let Some(translations) = TRANSLATIONS.get("en") { if let Some(translations) = TRANSLATIONS.get("zh") {
if let Some(text) = translations.get(key) { if let Some(text) = translations.get(key) {
if let Some(text) = text.as_str() { if let Some(text) = text.as_str() {
return text.to_string(); return text.to_string();
@ -85,15 +67,15 @@ pub fn t(key: &str) -> String {
fn get_system_language() -> String { fn get_system_language() -> String {
let sys_lang = sys_locale::get_locale() let sys_lang = sys_locale::get_locale()
.unwrap_or_else(|| String::from("en")) .unwrap_or_else(|| String::from("zh"))
.to_lowercase(); .to_lowercase();
let lang_code = sys_lang.split(['_', '-']).next().unwrap_or("en"); let lang_code = sys_lang.split(['_', '-']).next().unwrap_or("zh");
let supported_languages = get_supported_languages(); let supported_languages = get_supported_languages();
if supported_languages.contains(&lang_code.to_string()) { if supported_languages.contains(&lang_code.to_string()) {
lang_code.to_string() lang_code.to_string()
} else { } else {
String::from("en") String::from("zh")
} }
} }

View File

@ -19,8 +19,8 @@ const resources = Object.fromEntries(
i18n.use(initReactI18next).init({ i18n.use(initReactI18next).init({
resources, resources,
lng: "en", lng: "zh",
fallbackLng: "en", fallbackLng: "zh",
interpolation: { interpolation: {
escapeValue: false, escapeValue: false,
}, },