This mono-repository contains the source code for the web UIs of the following projects: Teleport Gravity Force
The code is organized in terms of independent yarn packages which reside in the packages directory.
You can make production builds locally or you can use Docker to do that.
Make sure that you have yarn installed on your system since this monorepo uses the yarn package manager.
Then you need download and initialize these repository dependencies.
$ yarn install
To build the Teleport web UI
$ yarn build-teleport
To build the Gravity web UI
$ yarn build-gravity
To build the Force web UI
$ yarn build-force
The resulting output will be in the /packages/{package-name}/dist/
folders respectively.
To build all packages
$ make all
To build the Teleport web UI
$ make packages/teleport/dist
To build the Gravity web UI
$ make packages/gravity/dist
To build the Force web UI
$ make packages/force/dist
To avoid having to install a dedicated Teleport or Gravity cluster, you can use a local development server which can proxy network requests to an existing cluster.
For example, if https://example.com:3080/web
is the URL of your cluster UI then:
to start your local Teleport development server
$ yarn start-teleport --target=https://example.com:3080/web
or to start your local Gravity development server
$ yarn start-gravity --target=https://example.com:3080/web
This service will serve your local javascript files and proxy network requests to the given target.
Keep in mind that you have to use a local user because social logins (google/github) are not supported by development server.
We use jest as our testing framework.
To run all jest unit-tests:
$ yarn run test
To run jest in watch-mode
$ yarn run tdd
We use storybook for our interactive testing. It allows us to browse our component library, view the different states of each component, and interactively develop and test components.
To start a storybook:
$ yarn run storybook
This command will open a new browser window with storybook in it. There you will see components from all packages so it makes it faster to work and iterate on shared functionality.
- Install plugin: https://github.com/prettier/prettier-vscode
- Go to Command Palette: CMD/CTRL + SHIFT + P (or F1)
- Type
open settings
- Select
Open Settings (JSON)
- Include the below snippet and save:
// Autoformat on save
"editor.formatOnSave": false,
// Specify prettier configuration file
"prettier.configPath": ".prettierrc",
"[javascript]": {
"editor.formatOnSave": true
},
"[javascriptreact]": {
"editor.tabSize": 2,
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[html]": {
"editor.tabSize": 2,
"editor.defaultFormatter": "esbenp.prettier-vscode"
}