Configuration
Most of our preferred style when writing TypeScript is configured in our.eslintrc.yml files.
We recommend enabling ESLint in your editor to catch style issues while you code.
Naming Conventions
Methods
Use camelCase for method names
Classes
Use PascalCase for class names
Documenting Your Code
We currently use JSDoc even though we don’t currently generate any documentation or verify the format. We’re using JSDoc over other formats because the TypeScript compiler has built-in support for parsing JSDoc and presenting it in IDEs.While there doesn’t appear to be any well-used TypeScript documentation export utilities out there at the moment, we hope that it’s only a matter of time. JSDoc uses a lot of metadata that is already self-documented in the TypeScript type system such as visibility, inheritance, and membership.
Basic Documentation
You can document classes, methods, properties, and fields using a formatted comment on the line above whatever you’re documenting:Multi-line Documentation
If you need multiple lines to describe the subject, sum up the thing you’re describing in a short title and leave a blank line before you go into detail (similar to a git commit message):AppStore Method Visibility
TheDispatcher is the entry point for most interactions with the application which update state, and for most usages this work is then delegated to the AppStore.
Due to this coupling, we need to discourage callers from directly manipulating specific methods in the AppStore unless there’s a compelling reason.
Making Methods Unappealing
We make methods look unappealing to discourage direct usage:- Underscore prefix on method name
- Comment indicating that you should be looking elsewhere
Asynchronous and Synchronous Node APIs
Application Code
We should be using asynchronous core APIs throughout the application, unless there’s a compelling reason and no asynchronous alternative. We also fall back toSync methods for readability in tests.
We use an ESLint rule to enforce this standard.
Scripts
For scripts, we favor synchronous APIs as the asynchronous benefits are not as important, and it makes the code easier to read.Code Examples
Immutability Pattern
Preferconst with conditional assignment:
Read-only Parameters
Use read-only arrays and objects in function parameters:Type Safety with assertNever
Use theassertNever helper to ensure exhaustive type checking: