mirror of
https://github.com/clash-verge-rev/clash-verge-rev
synced 2025-05-05 04:53:44 +08:00
fix: try to fix the language pack issue
This commit is contained in:
parent
146a66fb09
commit
d2f51ce509
@ -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()
|
||||||
|
@ -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")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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,
|
||||||
},
|
},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user