Getting Started

  • Clone the repo to your local environment. Then create a private repo in your github account and push.
  • Alternatively, you can fork this repo.

For local development, run the server:

pnpm dev

Open http://localhost:3000 with your browser to see the result. This is a basic create-next-app application, so act accordingly.

Context

Generic Crypto Company (GEN) is launching a new Decentralized Exchange (DEX) with integrated Automated Market Maker (AMM) and Staking/Farming features. A Senior Engineer asks you to contribute with some minor tasks - mainly front-end - to speed up the delivery. You have to complete them by making your own choices autonomously and being ready to discuss the tradeoffs you settled on while doing so.

Tasks

1 - Add background to navigation component on page scroll

When the user scrolls down the page, a backdrop should be shown behind the navigation (slightly transparent black background with blur)

2 - Enable scroll on modal component content

Currently the modal content does not scroll, the entire page scrolls instead. See the 'token list' modal on the swap page as an example. Apply the following changes when the modal component is open:

  • Block scrolling on the underlying body
  • Allow scrolling of the modal content inside of the fixed height of the modal window (mostly necessary for 'token list' modal)

3 - Fix premature closing behaviour on modal component

Example: 'token list' modal component When you click ('mousedown' event) inside the modal content, move your cursor outside of the modal and then release the click ('mouseup') the modal closes. This should be avoided. Make sure that the modal only closes on 'mousedown' when clicking on the modal backdrop.

4 - Add fade-in and fade-out effect to modal open and close

5 - Add global state management with local storage persistence

Add a lightweight global state management solution. The global state should be persisted entirely to local storage and loaded each time on app initialization. We could try to use Redux, Hookstate, Zustand or rely on React Context as well.

Currently we need to store only user settings:

slippage (number)
transactionDeadline (number)
disableMultihops (boolean)
tokens (Token[])

No database persistence needed for now.

Be ready to describe why you ended up choosing your preferred solution

Finish

Once you finished the tasks and are happy with the result please commit and push the changes to your repo, then share it with your reviewer.