Thanks for taking the time to contribute ! You can start by reading our Contribution guidelines first.
Create a .env.development.local
file at the root of the project. Add the following lines inside :
REACT_APP_CROWDIN_APIKEY = ""
REACT_APP_CROWDIN_PROJECTID = ""
You'll need this in order to get the i18n system to work. Contact a dev if you need these values.
Install the dependencies
yarn
yarn start
Don't forget to setup your IDE with eslint
and prettier
.
- components contains generic components used inside the application.
- views contains building blocks for each page. The entry point of a view is used as the root component of each route.
- config contains all the config files and ABIs.
- state contains the redux files for the global state of the app.
- context contains global contexts (separated from the redux store)
- hooks contains generic hooks.
- utils contains generic utilities functions.
Run tests with yarn test
.
In order for the Crowdin API queries to work - you will need REACT_APP_CROWDIN_APIKEY
& REACT_APP_CROWDIN_PROJECTID
env variables set in your root .env.development.local
file
A hook expose the function you need to translate content.
import useI18n from 'hooks/useI18n'
...
const TranslateString = useI18n()
...
TranslateString(id, 'fallback', data)
- id is the crowdin id of the string you want to translate.
- fallback is a string fallback used if the id cannot be found.
- data dynamic variables
If a Crowdin translation like this You have %num% left in your wallet
- would look something like:
TranslateString(675, `You have ${plantBalance} left in your wallet`, { num: plantBalance })
A bug is a demonstrable problem that is caused by the code in the repository. Good bug reports are extremely helpful - thank you!
Guidelines for bug reports:
-
Use the GitHub issue search — check if the issue has already been reported.
-
Check if the issue has been fixed — try to reproduce it using the latest
master
or development branch in the repository. -
Isolate the problem — create a reduced test case and a live example.
-
Add attachments — add photos or videos
A good bug report shouldn't leave others needing to chase you up for more information. Please try to be as detailed as possible in your report. What is your environment? What steps will reproduce the issue? What browser(s) and OS experience the problem? What would you expect to be the outcome? All these details will help people to fix any potential bugs.
Template:
**Environment:**
Device and OS:
Browser:
Reproducibility rate:
**Steps to reproduce:**
1.
2.
3.
**Expected result:**
A good bug report shouldn't leave others needing to chase you up for more.