The LOSH frontend is a monorepo comprising of a client and server package. The client is a React application built on the Gatsby framework using the GraphQL server as a data source.
- Gatsby v3 (React JS)
- Ant Design System
- Typescript
- Jest (Unit tests)
- Cypress (e2e tests)
- Typescript
- GraphQL
- Express
- Jest (Unit tests)
- Typescript
To develop the server package locally you will need SSH access to the Elastic web server.
-
Contact the administrator with an access request to the Elastic server along with a copy of your public key.
-
Setup your SSH config file for the host.
Host losh
Hostname opensourceecology.de
IdentityFile ~/.ssh/KEYFILE
Port 41022
User YOUR_USERNAME
- Create an SSH tunnel to the web server. (Replace YOUR_USERNAME with the username assigned by the administrator).
ssh -p 41022 -L 9200:elasticsearch.library-of-open-source-hardware.svc:9200 YOUR_USERNAME@opensourceecology.de
This will forward all requests to your local machine http://localhost:9200
through the web server.
Clone the repository
Run yarn
or yarn install
in the repostitory directory to install the dependencies.
To start the server in development mode:
Run yarn server start
The start the client in development mode:
Run yarn client start
To build the server package, there are two environment variables required:
ELASTIC_API_URL - Points to the Elastic instance WIKIBASE_API_URL - Points to the Wikibase REST API
Run yarn server build
. The compilation output will be in packages/server/dist
.
To build the client package, the URL of the deployed server package should be provided as an environment variable:
GRAPHQL_API_URL - Points to the deployed server package
Run yarn client build
. The compilation output will be in packages/client/public
.
Run all client tests using Jest
yarn client test:unit
Run yarn client test:e2e
to run the e2e tests with Cypress locally.
To run them headless/in a pipeline, use yarn client test:e2e:ci
.
After Building the packages, the client bundle in packages/client/public
can be hosted on any HTTP server (Apache, Nginx, Amazon S3, etc.)
The server bundle found in packages/server/dist
should be hosted on a node server and started using node server.js
Code style is enforced locally using Husky as a precommit hook, and is tested in the pipeline. Code that does not conform to the style will cause a build to fail.
If the pre-commit hooks are not working correctly, run yarn husky
to install the Git hooks.
- Commits must use the Conventional Commits format.
- Files are linted and formatted using a combination of ESLint and Prettier.
All files must be linted and formatted before committing changes. All staged files will automatically be linted/formatted using a git pre-commit hook. If you are running into issues with failing builds at the format stage in the CI pipeline, please check that the pre-commit hook is running properly on your local machine.
The following is a diagram of how the data sources are combined to supply the client application. Click here to be able to edit and view the diagram on swimlanes.io