Code should be written in TypeScript. Should you not be familiar with TS, the official website hosts several quick-start guides and comprehensive documentation.
The frontend framework is React. In conjunction with React Native we can build components that can be re-used for web, iOS, and Android applications. If you're unfamiliar with React, the official website has an interactive tutorial. React code should be written using TypeScript.
- Fork the project on Github
- Clone your fork to your computer
- Run
yarn
Flagship packages utilize the React Typescript Standards module which is a common set JS/Typescript/JSX linter rules as well as a harness for running the linter and the packages's tests as pre-commit hooks.
See the documentation for an up-to-date summary of important rules as well as descriptions of all enforced rules.
The codestyle package will prevent you from committing code if the linter or tests fail.
Should you need to disable a linter rule, follow the
instructions provided by TSLint. Do not
bypass the commit hook with the -n
flag as your PR will be rejected by our CI.
Tests should be written for
Jest and located in
a __tests__
directory next to the code under test per Jest conventions.
To run tests, run yarn test
To increase the likelihood that your code is merged, please create tests for any new code that you write and modify existing tests that are impacted by code that you modified.
Pull requests will not be merged if tests fail during integration testing.
When creating a pull request, please include the following:
- A useful description of the issue solved or new features implemented
- Instructions for testing your changes
When you create a pull request, our continuous integration server will run the linter and tests against your branch. The status of the integration tests will appear on the pull request in Github. If the linter or tests fail the pull request will be blocked from being merged.
Your pull request must be approved via the Review function prior to being merged.
Please contact the Product Team: [email protected]