In each frontend repo (frontend, frontendapp..., frontend_lib), there is a folder i18next.scanner that holds every translation files in JSON.
If the error is in any language other than english:
a) you can edit the values of the json files.
b) Then commit/push your changes
If the error is in en.json:
1) You must find the key in the according .jsx file of that same repo.
2) Fix the error
3) Rebuild the translation files with:
npm run build-translation
This will add your new key in the translation files and remove the old one.
4) Add translations for your new key in other .json files.
5) commit/push your changes
It means you have found an english text although you have selected another language.
Do task a) and b) in the according .json file. In folder i18next.scanner.
Do step 3).
If the key still isn't in the .json file, it means the text in the .jsx file does not implement the translation process.
So you must:
I) Find the according .jsx file that have your untranslated key
II) wrap your untranslated key in the translation function t
:
Exemple: <div>My untranslated key</div>
will become <div>{this.props.t('My untranslated key')}</div>
III) Check that t
in available in your component, meanings your component must be wraped in the translate()
higher order function
import { translate } from 'react-i18next'
class MyComponent extends React.Component {
render () {
return (<div>{this.props.t('My untranslated key')}</div>)
}
}
export default translate()(MyComponent)
IV) You can destruct t
from this.props
in the render()
like it is done in most components.
V) Do steps 3), 4), 5)