1
0
mirror of https://github.com/quay/quay.git synced 2026-01-26 06:21:37 +03:00
Files
quay/web
jbpratt a092721b73 feat(ui): add footer links to login page (PROJQUAY-9152) (#4378)
* feat(ui): add footer links to LoginPage and CreateAccount (PROJQUAY-9152)

Adds configurable footer links (Terms of Service, Privacy Policy, Security,
About, Documentation) to the signin and create account pages using PatternFly's
LoginPage footerListItems prop. Creates a reusable useLoginFooterItems hook that
reads footer configuration from FOOTER_LINKS config.

Co-authored-by: Claude <noreply@anthropic.com>

* refactor(ui): extract LoginPageLayout to eliminate duplication (PROJQUAY-9152)

This extracts common LoginPage configuration into a reusable LoginPageLayout
component, eliminating ~27 lines of duplication between CreateAccount and Signin.

The component encapsulates logo URL logic, footer items hook, document.title
effect, and all LoginPage props. Also moves brand CSS to LoginPageLayout.css
to fix logo sizing.

Fixes bugs: CSS typo in CreateAccount (pdf-u- → pf-u-) and missing document.title.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
Signed-off-by: Brady Pratt <bpratt@redhat.com>

---------

Signed-off-by: Brady Pratt <bpratt@redhat.com>
Co-authored-by: Claude <noreply@anthropic.com>
2025-10-17 09:02:29 -05:00
..
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00
2022-12-20 08:38:16 -05:00

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

git clone https://github.com/quay/quay-ui.git
cd quay-ui
npm install

Development

Start the dev server by running

npm start

Runs the app in the development mode.
Open 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

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

npm test

Launches the test runner in the interactive watch mode.
See the section about running tests for more information.

Integration Tests

Integration tests are ran via Cypress. 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

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 for more information.