Skip to content

Latest commit

 

History

History
64 lines (44 loc) · 2.76 KB

README.md

File metadata and controls

64 lines (44 loc) · 2.76 KB

This is a Next.js project bootstrapped with create-next-app.

Getting Started

First, run the development server:

npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying app/page.tsx. The page auto-updates as you edit the file.

This project uses next/font to automatically optimize and load Geist, a new font family for Vercel.

Learn More

To learn more about Next.js, take a look at the following resources:

You can check out the Next.js GitHub repository - your feedback and contributions are welcome!

Your task

You have been given the following mock-up design:

design

Part 1 (Tailwind, React)

Your task is to implement the slider component of the design. It has the following requirements:

  1. The cards should slide across the screen infinitely.
  2. When the user hovers over the cards the cards should slow down to an eventual stop and then resume sliding when the user stops hovering.
  3. If a specific card is hovered an interesting and dynamic hover effect should be applied.
  4. Clicking on one of the cards should open a modal with a larger version of the card fixed to the center of the screen.
    1. There is no design for the look of this modal so you will have to be creative here.
    2. Bonus points for if you are able to animate the card from its small version to the full version seamlessly.
  5. The component should be fully responsive.

Part 2 (Next.js)

  1. The list of items should come from an API. Make user of Next.js route handlers to create a mock route: https://nextjs.org/docs/app/building-your-application/routing/route-handlers
  2. The mock route should return a list of the cards.
  3. Simulate a long running request by setting a timeout.
  4. Create a second route that always returns an error after a few seconds.
  5. Call the first route from the client and populate the cards with the data from the API.
  6. Call the second (broken) route and demonstrate how your component will gracefully handle the error.

Technical requirements / considerations

  1. Careful consideration should be given to any additional dependencies.
  2. The slider component should take in list of items to display as props.
  3. Strict typescript types should be in place.
  4. Make sure to handle loading and error states correctly.