this post was submitted on 21 Aug 2023
35 points (100.0% liked)
Programming
17366 readers
508 users here now
Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!
Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.
Hope you enjoy the instance!
Rules
Rules
- Follow the programming.dev instance rules
- Keep content related to programming in some way
- If you're posting long videos try to add in some form of tldr for those who don't want to watch videos
Wormhole
Follow the wormhole through a path of communities !webdev@programming.dev
founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
If you are using TypeScript it's quite easy to create a system where the type system will enforce the existence of all translations. I think it should be possible to create a similar solution for other languages as well.
For example:
Missing keys will fail compilation. If you want to skip check you can always use //@ts-ignore
Additionally the type system will enforce only valid translation keys so you won't be able to make a typo it forget to add English translation.
I think I actually just want a system, which will take my English file as the default, and add the missing keys to the rest of the language files.
Perhaps, the "fallback to English translations file at runtime" is obscuring errors.
Might be worth redefining the system to throw an error when a translation key in the chosen language isn't found. Even if that's only done in Dev, whereas the fallback happens in prod.
This will ensure a translation file has all the keys, even if the values are still default.
Some tooling for you to easily add a new key, and have it also add that to all language files as
[word]
or something. So, the English word is still used, but the square brackets shows that it's untranslated.Maybe some tooling to find all values that have the
[]
, to generate a translation to-do list.Probably a tool to create a new translation file as well, which would duplicate the English file, but apply the "this is not translated" pattern to all the values
Are warnings no thing anymore?
We ignore them.
Quite a lot of IDEs will key you just click "add missing properties" action on the translation object to create a language file.
Obviously I don't know your codebase but couldn't you do something like the following?
That won't work quite well because a lot of it is nested. But shouldn't be too hard to account for that in a couple of lines of code.
Yeah, I don't know the exact structure of your translation files but a deep merge of your fallback files and the requested locale file should be enough.
Sounds like that will be indeed the easiest and quickest solution for this project.
It's also quite ready to transform this file to JSON and send it to translators through any service that supports his format.