Skip to content

Latest commit

 

History

History
 
 

vtadmin

VTAdmin

Prerequisites

  • 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 running npm run build. This is due to node dropping support for older versions of openssl. A workaround was added in nodejs/node#40455, allowing you to export NODE_OPTIONS="--openssl-legacy-provider" before running npm run build.
  • npm >= 8.1.0 (comes with node)

Available scripts

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.

Toolchain

Environment Variables

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.

Linters and Formatters

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.

Configuring your editor

VS Code

To set up automatic formatting on save:

  1. Install the Prettier VS Code plugin.
  2. 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.