This frontend is part of a bigger application, before going further, please go to the main project README, where you can find an introduction.
A hosted version of this application can be found at https://shareyourcloning.org/.
If you want to quickly set up a local instance of the frontend and backend of the application using Docker, check getting started in 5 minutes in the main repository.
We use node 18.8, to manage different versions of node, we use nvm
. Installation instructions here.
# Install node 18.8 (first time only)
nvm install 18.8
# Activate node 18.8
nvm use 18.8
To handle dependencies and build the site, yarn 3 is used.
# Enable yarn 3 in the project (first time only)
corepack enable
# Install dependencies (every time you pull changes)
yarn install
# If you want to serve the development site locally at http://localhost:3000/
yarn start
# If you want to build the statics assets of the production site in the folder ./build
yarn build
For the application to work, you must have a running backend. For that, see the backend installation instructions.
By default, if you run the dev server with uvicorn main:app --reload --reload-exclude='.venv'
, the backend will be running at http://localhost:8000/
. That's where the dev server of the frontend (ran with yarn start
) will send the requests to by default.
The backend URL can be changed by setting a different value in the config.json
(see next section).
See also connecting to the frontend section in the backend repo.
The configuration of the frontend is done in the file that will be served from /config.json
. In the dev server, this file is served from public/config.json
. That file is not included in the repository, and is generated from public/config.dev.json
when you run yarn start
. For the production site, config.prod.json
is used. The things you can configure are:
backendUrl
: The URL of the backend. By default, it ishttp://localhost:8000/
.
For production: when building the site with yarn build
, simply replace build/config.json
with your settings. This is what is done in this docker-compose file.
If you want to serve the full site (backend and frontend) with docker, check getting started in 5 minutes in the main repository.
If you want to serve only the frontend from a docker container, an image is available at manulera/shareyourcloningfrontend. The image is built from the Dockerfile in the root of this repository and exposes the port 3000. To run it:
docker pull manulera/shareyourcloningfrontend
docker run -p 3000:3000 manulera/shareyourcloningfrontend
Check contribution guidelines in the main repository.
For the eslint
to work, you will need the eslint module
To run the tests, first run the dev server with yarn start
.
To run most tests, you will need the backend to be running at http://localhost:8000/. You can see how to do run it in the backend repo. For the github actions tests, a submodule is used (see below).
To run the tests:
# Open cypress UI
yarn cypress open
# Run a particular test in the command line
yarn cypress run --spec cypress/e2e/source_genome_region.cy.js
# Run a few tests in parallel from the command line (edit file if needed)
bash run_tests_in_parallel.sh
# If the tests fail, you can see screenshots of the failed tests in the folder cypress/screenshots
The tests run with cypress in github actions require the submodule ShareYourCloning_backend to be included. If you want to include it locally:
git submodule update --init
If you want to change the commit of the submodule:
cd ShareYourCloning_backend
git checkout -b the-branch
git pull origin the-branch
cd ..
# commit the frontend repo normally
You can configure website analytics using umami by setting the env var VITE_UMAMI_WEBSITE_ID
to the website id. When building the site, the analytics script will be included in the build. See index.html
and vite.config.js
to see how this is done (using ejs templating).
Settings (they can also be set as env vars or passed with flags).
module.exports = defineConfig({
video: true,
viewportWidth: 1000,
viewportHeight: 1000,
...
Then, when running the video.
CYPRESS_NO_COMMAND_LOG=1 yarn cypress run --spec cypress/e2e/source_genome_region.cy.js
The API keys should be in the ignored file .env.development.local