This document describes how to set up your development environment to build and develop aerie-ui.
- Prerequisite Knowledge
- Prerequisite Software
- Code Editor
- Getting the Sources
- Installing NPM Modules
- Start Development Server
- Building For Production
- Cleaning
Before getting started with developing in this repository read/watch all of the following resources:
Before you can run aerie-ui you must install and configure the following products on your development machine:
-
Git and/or the GitHub app; GitHub's Guide to Installing Git is a good source of information.
-
Node.js LTS which is used to run a development web server, and generate distributable files. We recommend using the Node Version Manager (NVM) to install Node.js and NPM on your machine. Once you have NVM installed you can use the required Node.js/NPM versions via:
cd aerie-ui nvm use
-
OpenJDK Temurin LTS which is used to build the Java-based Aerie services. If you're on OSX you can use brew:
brew tap homebrew/cask-versions brew install --cask temurin19
Make sure you update your
JAVA_HOME
environment variable. For example with Zsh you can set your.zshrc
to:export JAVA_HOME="/Library/Java/JavaVirtualMachines/temurin-19.jdk/Contents/Home"
-
Docker which is used to run the Aerie services.
-
Aerie which contains the main backend services. You can use the following commands to download, build, and run Aerie:
git clone https://github.com/NASA-AMMOS/aerie.git cd aerie cp .env.template .env
Fill out the
.env
file with the following default environment variables:AERIE_PASSWORD=aerie AERIE_USERNAME=aerie HASURA_GRAPHQL_ADMIN_SECRET=aerie HASURA_GRAPHQL_JWT_SECRET='{ "type": "HS256", "key": "oursupersecretsupersecurekey1234567890" }' POSTGRES_PASSWORD=postgres POSTGRES_USER=postgres
Next build Aerie, and start the services via Docker:
./gradlew assemble # Notice we exclude the aerie_ui since we run it locally (i.e. not in Docker) for development. docker-compose up --build --detach aerie_gateway aerie_merlin aerie_scheduler aerie_merlin_worker_1 aerie_merlin_worker_2 aerie_scheduler_worker_1 aerie_scheduler_worker_2 aerie_sequencing hasura postgres
To stop and clean the Aerie services do:
cd aerie docker-compose down docker rmi aerie_merlin aerie_scheduler aerie_merlin_worker_1 aerie_merlin_worker_2 aerie_scheduler_worker_1 aerie_scheduler_worker_2 aerie_sequencing docker volume prune --force ./gradlew clean
You should stop and clean the Aerie services after each use (e.g. at the end of the day), or right after pulling down the latest changes.
The recommended editor for developing aerie-ui is VS Code with the following settings and extensions. You can easily use another editor of your choice as long as you can replicate the code formatting settings.
Your editor should follow the same settings found in .vscode/settings.json.
- Svelte for VS Code
- Prettier - Code formatter
- ESLint
- Stylelint
- EditorConfig for VS Code
- GraphQL
- Path Intellisense
- Code Spell Checker
Clone the aerie-ui repository:
git clone https://github.com/NASA-AMMOS/aerie-ui.git
cd aerie-ui
Install the JavaScript modules needed to build aerie-ui:
npm install
Run npm run dev
for a dev server. Navigate to http://localhost:3000/
. The app will automatically reload if you change any of the source files. Since we have observed some issues using monaco-editor with the dev server on Firefox, we recommend using Chrome for development.
Run npm run build
to build a production version of the project. The build artifacts will be stored in the build/
directory.
Run the following commands to clean dependencies and build artifacts of aerie-ui. To be safe you should do this anytime you pull down the latest changes.
cd aerie-ui
rm -rf node_modules
rm -rf .svelte-kit
rm -rf build
After cleaning you can re-install NPM modules and start development.