- node >= 16.13.0 LTS
- Note: If you are using Node >= 17.x.y, you may see errors like
Error: error:0308010C:digital envelope routines::unsupported
when runningnpm run build
. This is due to node dropping support for older versions ofopenssl
. A workaround was added in nodejs/node#40455, allowing you toexport NODE_OPTIONS="--openssl-legacy-provider"
before runningnpm run build
.
- Note: If you are using Node >= 17.x.y, you may see errors like
- npm >= 8.1.0 (comes with node)
Scripts for common and not-so-common tasks. These are always run from the vitess/web/vtadmin
directory (although some of them have counterparts in vitess/Makefile
):
Command | Description |
---|---|
npm local |
Start vtadmin-web in development mode on http://localhost:3000, pointed at a vtadmin-api server running on http://localhost:14200. This is most useful when running against a local Vitess cluster. |
npm start |
Start vtadmin-web in development mode on http://localhost:3000. Additional environment variables can be specified on the command line or in a .env file; see Environment Variables. |
npm run test |
Launches the test runner in the interactive watch mode. See the create-react-app documentation about running tests for more information. |
npm run lint |
Run all of the linters and formatters. The package.json file defines a bunch more scripts to run individual linters, if you prefer, like npm run lint:eslint . |
npm run lint:fix |
Run all of the linters and fix errors (where possible) in place. Note that this will overwrite your files so you may want to consider committing your work beforehand! |
npm run build |
Generates a build of vtadmin-web for production and outputs the files to the vitess/web/vtadmin/build folder. In most cases, you won't need to run this locally, but it can be useful for debugging production-specific issues. See the create-react-app documentation about deployment for more information. |
- React
- create-react-app (generated with v.4.0.1)
- TypeScript
- protobufjs
- tailwindcss
Under the hood, we use create-react-app's environment variable set-up which is very well documented: https://create-react-app.dev/docs/adding-custom-environment-variables.
All of our environment variables are enumerated and commented in react-app-env.d.ts. This also gives us type hinting on process.env
, for editors that support it.
We use three libraries for consistent formatting and linting across the front-end codebase. (Not quite as streamlined as Go, alas!) These can be run individually, as noted below, or all in sequence with npm run lint
.
Library | Commands | What it's for |
---|---|---|
eslint | npm run lint:eslint npm run lint:eslint:fix |
ESLint identifies potential bugs and other issues. vtadmin-web uses the default ESLint configuration built in to create-react-app. |
prettier | npm run lint:prettier npm run lint:prettier:fix |
Prettier is an "opinionated code formatter" run against our JavaScript, TypeScript, and (S)CSS code to ensure a consistent style. Prettier is not a linter, and so it complements (rather than replaces) eslint/stylelint. |
stylelint | npm run lint:stylelint npm run lint:stylelint:fix |
Stylelint is a linter for CSS/SCSS. Whereas prettier's CSS/SCSS support is largely focused on formatting (newlines, spaces vs. tabs), stylelint is able to flag possible errors, limit language features, and surface stylistic issues that prettier isn't intended to catch. |
To set up automatic formatting on save:
- Install the Prettier VS Code plugin.
- Add the following to your VS Code workspace:
{
// ... other workspace config ...
"settings": {
// ... other settings ..
"prettier.useEditorConfig": false,
// You may have to adjust this depending on which folder is the root of your workspace.
// By default, this configuration assumes that you have your workspace settings
// at `vitess/.vscode/settings.json`.
"prettier.configPath": "web/vtadmin/.prettiercc",
"[typescriptreact]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
},
"[typescript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
},
"[javascript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
},
"[css]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.stylelint": true
}
},
"[scss]": {
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.stylelint": true
}
}
}
}
For more, check out "Setting Up Your Editor" in the create-react-app docs.