1
0
mirror of https://github.com/quay/quay.git synced 2026-01-26 06:21:37 +03:00
Files
quay/web/README.md
Dave O'Connor f1d8558815 Add quay-ui (#1683)
Signed-off-by: Dave O'Connor <1656866+HammerMeetNail@users.noreply.github.com>
2022-12-20 08:38:16 -05:00

72 lines
2.0 KiB
Markdown

# Quay UI
UI for Quay based on React and Patternfly framework
## Installation
It is assumed that you have a Quay instance running that you can point the UI to.
Run the following commands to get started
```bash
git clone https://github.com/quay/quay-ui.git
cd quay-ui
npm install
```
## Development
Start the dev server by running
```bash
npm start
```
Runs the app in the development mode.\
Open [http://localhost:9000](http://localhost:9000) to view it in the browser.
The page will reload if you make edits.\
You will also see any lint errors in the console.
By default the UI connects to the quay backend for API. If you don't have
a backend or want to develop without a backend you can set the environment
variable `MOCK_API=true` before running `npm start`.
In order for you to use this with a Quay backend, you need to configure CORS on the Quay side.
Add the following to your `config.yaml` in Quay
```yaml
CORS_ORIGIN: "http://localhost:9000"
```
If you are using `docker-compose` for local development, you can add this to `local-dev/stack/config.yaml`
in the Quay repo.
## Testing
```bash
npm test
```
Launches the test runner in the interactive watch mode.\
See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
### Integration Tests
Integration tests are ran via [Cypress](https://docs.cypress.io/). The URL under test defaults to `http://localhost:9000` and can be overriden with the `baseUrl` parameter in the `cypress.config.ts` file.
To run tests locally:
- Start the application with `npm start`
- When application has started run the tests with `npm run test:integration`
## Building for Production
```bash
npm run build
```
Builds the app for production to the `dist` folder.\
It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes.
See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.