This repository is for the frontend web application side of FIA which has been using Yarn, React, Typescript, Material-UI and serves as a plugin for SciGateway. The application allows for users to view and manage runs and reductions performed by ISIS instruments.
FIA is in the early stages of development and is continuously being worked on.
To get started developing for the frontend, first you will need to have Node.js and Yarn installed and set-up on your machine. When following the install wizards just keep to default settings. You will then want to clone the SciGateway repository. From now on stick to SciGateway's release/v2.0.0
branch (worth noting that develop
is the repository's default branch).
With that done, you can now clone the FIA frontend repository.
The frontend works by building the project and then running it through SciGateway as a plugin. You will want to create a settings.json
file in SciGateway's public
folder. Do this by simply duplicating settings.example.json
, renaming it, then adding FIA as a plugin with what port to listen on:
// settings.json
"plugins": [
{
"name": "fia",
"src": "http://localhost:5001/main.js",
"enable": true,
"location": "main"
}
]
A dev-plugin-settings.json
file is also needed in SciGateway's micro-frontend-tools
folder. Like before, simply duplicate dev-plugin-settings.example.json
, rename it, and add the path to the FIA frontend build folder:
// dev-plugin-settings.json
"plugins": [
{
"type": "static",
"location": "C:\\[path]\\[to]\\[frontend\\[build]\\[folder]",
"port": 5001
}
]
Unless you have a working API and data-viewer set-up locally you will want the frontend to point to the ones in staging which require your machine to be on the company VPN. The URLs for the REST_API
and DATA_VIEWER
are found in .env
.
Assuming all the previous steps have been completed, you can now use these commands in the terminal to get the web application running.
Installs the necessary dependencies for the project. You will also need to run this after adding new dependencies or switching to branches with a modified package.json
file.
Builds the app for production. You will need to do this every time the frontend changes as the build
folder isn't tracked by Git and SciGateway uses this folder to display the frontend.
You can now open a terminal in SciGateway and have it act as a parent application for running the frontend. You only need to run yarn start
and the FIA frontend will be running on http://localhost:3000/fia.
If you're testing changes that don't strictly need SciGateway, the API, or the data-viewer, you can run the frontend on its own by running yarn start
in the frontend directory. This will also be running on http://localhost:3000/fia.
Certain features of the frontend such as the help page are handled by files in SciGateway which are overwritten during production to display the correct information to users. Files for this purpose are stored in the container
folder. Any changes made locally to this folder won't be visible when running the web application using yarn start
. So to test changes you need to create a container image. To do this we recommend installing and using Docker.
docker build . -t ghcr.io/fiaisis/frontend -f ./frontend.dockerfile
docker build . -t ghcr.io/fiaisis/scigateway -f ./scigateway.dockerfile
docker run --rm -it -p 8080:80 ghcr.io/fiaisis/frontend
To run the SciGateway container (NOTE: without the frontend running on the same local network this will not display the plugin):
docker run --rm -it -p 8080:80 ghcr.io/fiaisis/scigateway
To access the websites made by the above containers navigate to http://localhost:8080.
As an alternative to testing using containers, you can replace the contents of SciGateway's res
folder with the frontend's default.json
file and images
folder. This will allow you to see the changes made by running yarn start
.
BEWARE: this can give false positives. And do not push changes to SciGateway.
When adding new depencies to package.json
or switching between branches with different dependencies, you will need to run yarn install
to update the node_modules
folder.
Occassionally there are issues with package conflicts that require node_modules
and yarn.lock
to be deleted and the cache cleared. You can do this with the following command:
rm -rf node_modules && yarn cache clean && rm -f yarn.lock && yarn install
The FIA frontend makes use of Cypress for conducting end-to-end and component testing. These tests will be ran by a workflow whenever a commit is pushed or a pull request merged. The tests can also be ran locally.
For writing your own tests, follow the guide here. Alternatively you can replicate the methods used in pre-existing .cy.tsx
files, like the home page.
Here are a few other scripts to be aware of:
Note: this is a one-way operation. Once you eject
, you can’t go back!
If you aren’t satisfied with the build tool and configuration choices, you can eject
at any time. This command will remove the single build dependency from your project.
Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except eject
will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
You don’t have to ever use eject
. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
Opens the Cypress Test Runner. This provides a graphical display for running end-to-end and component tests within a browser.
Runs Cypress tests headlessly in the terminal. This is useful for running tests in a CI/CD pipeline (currently there are no e2e spec files so shouldn't do anything).
Builds the frontend and then navigates to the SciGateway
folder (assuming it's in an adjacent directory) and runs yarn start
there. Makes testing easier.
You can learn more in the Create React App documentation.
To learn React, check out the React documentation.