Your task is to develop and enhance a Mock React application designed to help users find a restaurant and book a table.
The application currently displays a static list of restaurants. You need to integrate it with a dynamic data source to load restaurants, display the restaurant details, and handle bookings.
- Static Setup: The app displays a single static restaurant in the
RestaurantList
component. - Mock Server:
mock-server.json
provides data for restaurants and bookings. This is served via json-server at/restaurants
and/bookings
.
-
Fetch and Display Restaurants:
- Use the provided
services/api.ts
to fetch data from the API endpoints (/restaurants
and/restaurant/:id
). - Populate the
RestaurantList
component with dynamic data.
- Use the provided
-
Restaurant Details:
- When a restaurant is selected, display detailed information about it, including opening hours and rating, in the
RestaurantDetails
component.
- When a restaurant is selected, display detailed information about it, including opening hours and rating, in the
-
Booking a Table:
- Implement the
BookTable
component to handle booking requests. - On form submission, POST the booking data to the
/bookings
endpoint. - Ensure the following validation rules:
- Date/Time: Bookings must be scheduled for at least 1 hour in the future and cannot be set for the past.
- Guests: Limit bookings to a maximum of 12 people. Inform users to contact the restaurant directly via email if booking for more than 12.
- Form Validation: Ensure the presence of required fields (name, email, phone), validity of email and phone number, and check for the number of guests.
- Implement the
-
Search and Sorting:
- Implement search functionality to filter the restaurant list.
- Allow sorting of the restaurant list alphabetically by name or by rating.
-
Error Handling & UX Optimisation:
- Handle cases where the server is not running or responding slowly.
- Display loading spinners or messages to inform users when requests are in progress or if errors occur.
- Ensure a responsive and intuitive User Interface with appropriate feedback for user actions.
-
Performance:
- Optimise the app to handle slow network conditions gracefully and ensure smooth UX even on slower connections.
-
Testing:
- Write tests to ensure the functionality of search, sorting, booking, and error handling.
- Get Restaurants:
GET /restaurants
- Get Restaurant Details:
GET /restaurants/:id
- Post Booking:
POST /bookings
-
Run json-server:
- Start json-server to serve
mock-server.json
:
yarn server
- The server will be accessible at http://localhost:3001.
- Start json-server to serve
-
Endpoints:
- Restaurants: http://localhost:3001/restaurants
- Bookings: http://localhost:3001/bookings
This project was bootstrapped with Create React App.
In the project directory, you can run:
Runs the app in development mode.
Open http://localhost:3000 to view it in the browser. The page will reload if you make edits.
You will also see any lint errors in the console.
Launches the test runner in interactive watch mode.
See the section about running tests for more information.
Runs json-server in development mode.
Open http://localhost:3001 to view it in the browser.
-
Functional Requirements:
- Correctly fetches and displays dynamic data
- Handles booking submissions
- Appropriately handles and adheres to validation for submissions
- Implements search and sorting
-
User Experience:
- Smooth, responsive user interface
- Appropriate feedback to user for loading, errors, and network issues.
-
Code Review:
- We will review your code for clarity, structure, and adherence to React best practices.
- We will also review your tests for coverage and correctness.
-
Bonus Points:
- Regular commits with clear commit messages, demonstrating your thought process and approach.
- Any additional improvements that enhance the performance or functionality beyond the brief will be appreciated.
- Future-proofing the application for scalability, resiliance, reliability and maintainability.
-
Submission:
- Once you have completed the task, please commit your changes and push them to a forked repository and share the link with us.
- We'll then arrange a follow-up call to discuss your solution and answer any questions you may have.
- The mock-server.json file contains the data for the restaurants and will be served by json-server.
- The mock-server.json will also be populated with booking data when you submit a booking form. You can check the file to see all of your booking data is being submitted and stored.
- We're not looking for a perfect solution, or lots of UI creativity, but we want to see how you approach the problem and your thought process.
Good luck, and happy coding!
Restaurant List and Details are being fetched from the server - implemented using Tanstack Query. The List takes in a searchValue, which is debounced to prevent an overload of requests. It is also possible to sort by Ascending and Descending. The sort function also handles numbers in the string, so Restaurant 3 will appear before Restaurant 10.
BookTable implements Zod and React Hook Form for client-side validation of the form. It implements custom date and time validation to ensure it is in the future and an hour ahead per requirements.
There a few scattered TODOs throughout the codebase. These relate to either error/loading states and improve any existing functionality for a better UX. It also includes the question about moving types to a dedicated file.
Implementing useOptimistic, or some form of optimistic UI, would be benefical for UX and will make the application feel smoother, espeically for slower devices. Tanstack Query allows for automatic and manual retries of mutations in case these failed.
Sorting functionality currently utilises the name, in ascending or descending order, but rating should also be implemented. This would probably be implemented by reducing the current button and use icons, and Aria Labels for accessibility.
Additionally, the current functionality is only client-side so upon refresh, state is lost. Next steps would be to look at hoisting state up tot the URL and using that as a source of truth - potentually implementing a library like react-router to allow this.
Implementing Unit, E2E, and Integration Tests would be important at some point. A specific scenario would be mocking external API calls to make sure they are returning data as expected, and mutations are inserting/updating correctly. This would also allow for higher confidence in refactors as can test existing functionality isn't broken.
Once functionality is completed. a review of the UI would be neede to ensure it is more responsive, it adheres to accessibility and implemented better UX, such as feedback when submitting a form.