@thomei,
In German we use informal ans formal translations. The correct translations code is “de_CH_informal”
Glad you figured it out!
This brings up lack of the LifterLMS:
All other Plugins I know and WP itself, fall automatically back to the closest, if the desired translations isn’t available. Not do English in first stage.
Are you certain about this? I’ve done a bit of digging through some code bases and reviewed (again) the plugin developers handbook to see if something has changed recently but I can’t find any evidence anywhere of some intelligent fallback built into WordPress.
I feel like it is possible to build a database of fallbacks and load them but my experience with translation is that this will actually cause more support requests and confusion for our users since it will be loading languages that aren’t expected. Maybe I’m wrong about this but I think it will.
This is what LifterLMS does already, basically, with some customization to allow you to load from a custom location (we do this so you can load translations from a “safe” place that won’t be overwritten by automatic downloads from the translate.www.ads-software.com GlotPress instance): https://developer.www.ads-software.com/plugins/internationalization/how-to-internationalize-your-plugin/#loading-text-domain
The underlying functions don’t have any “fallback” logic built into them.
Furthermore, I don’t see any evidence of the WordPress core doing this either, I’ve found a track ticket about it that hasn’t been resolved: https://core.trac.www.ads-software.com/ticket/28197
Do you have some example plugins you know of that absolutely do do this so I can review their code and learn how this is working to improve LifterLMS?
I’m ALWAYS looking to improve LifterLMS but I don’t actually feel in this circumstance that we’re doing anything incorrectly or that we’re even not following best practices set forth by the handbook or by standard plugin conventions.
Thanks,