61 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
## Helping with Translations
 | 
						|
 | 
						|
All interface translations can be found inside the folder:
 | 
						|
 | 
						|
📁 `apps/ui/src/lib/locales`
 | 
						|
 | 
						|
> The base and fallback language is 🇬🇧 `en`.
 | 
						|
 | 
						|
---
 | 
						|
 | 
						|
## 🖐️ Manual First steps
 | 
						|
 | 
						|
To start translating to a new language:
 | 
						|
 | 
						|
1. create `apps/ui/src/lib/locales/jp.json` (change `jp` to chosen language)
 | 
						|
2. copy the contents from `apps/ui/src/lib/locales/en.json` to your new json.
 | 
						|
2. edit `apps/ui/src/lib/translations.ts`
 | 
						|
* 2.1. add `jp: { lang },` inside `translations:`
 | 
						|
* 2.2. duplicate the full `en` locale hash inside `loaders:`, change `en` to `jp`(chosen locale)
 | 
						|
 | 
						|
Congratulations! You are now ready to start translating
 | 
						|
 | 
						|
## 🤖 Automated First Steps
 | 
						|
 | 
						|
We can ease the translation using [MoloLab Json Translator](https://github.com/mololab/json-translator):
 | 
						|
 | 
						|
```sh
 | 
						|
# Install Json Tranlator
 | 
						|
npm i -g @parvineyvazov/json-translator
 | 
						|
# Run this command to create a new translation:
 | 
						|
jsontt apps/ui/src/lib/locales/en.json
 | 
						|
 | 
						|
# Example Result:
 | 
						|
jsontt apps/ui/src/lib/locales/en.json
 | 
						|
? From which source? #ArgosTranslate
 | 
						|
? From which language? #Automatic
 | 
						|
? To which language | languages? #Spanish
 | 
						|
✔ DONE! 287 of 287 translated.
 | 
						|
 All files are created! 
 | 
						|
 You can find them in the same folder as the original JSON file. 
 | 
						|
 For Spanish --> es.json created. 
 | 
						|
```
 | 
						|
 | 
						|
## Currently supported locales
 | 
						|
 | 
						|
- [x] en
 | 
						|
- [x] fr
 | 
						|
- [x] pt (autogenerated - needs review)
 | 
						|
- [x] es (autogenerated - needs review)
 | 
						|
- [x] ko (autogenerated - needs review)
 | 
						|
 | 
						|
## ☑️ Todo:
 | 
						|
 | 
						|
- [ ] Write a script to 
 | 
						|
  - sync missing keys from `en` to other locales;
 | 
						|
  - remove deprecated keys from all non `en` locales;
 | 
						|
 | 
						|
- [ ] Sveltekit-i18n instructs to create one locale file per path, maybe we should review that soon.
 | 
						|
 | 
						|
- [ ] Improve the aesthetics of `<LocalePicker/>`
 | 
						|
- [ ] Make selected locale persistent (in session or cookie) |