Thank you for participating in the 2021 - Q4 React Bootcamp! Here you will find all the instructions to complete your Capstone Project.
The purpose of this project is for you to demonstrate your React skills. This is your chance to show off everything you have learned during this bootcamp!
You will build and deliver an entire React application on your own from scratch. The project is divided into weekly deliverables, in which you will apply the concepts learned in the assignments and live sessions. Each deliverable has its own information on what and how we expect you to deliver throughout the bootcamp.
We hope you find this project challenging and engaging!
Create an Ecommerce Store where you can buy furniture and home decor items. It should have the following sections:
- Home Page
- Product List Page
- Product Detail Page
- Search Results Page
- Shopping Cart Page
- Checkout Page
We don’t want to limit you or bias your implementation by providing some demo application with a specific design, but instead, ask you to choose your own and build it from scratch. Here’s a link where you can find great ideas and inspiration for your UI design: https://dribbble.com/search/ecommerce
We provide the delivery dates to plan accordingly; please take this project seriously and try to make progress constantly. If you are struggling with something or get stuck at some point, please schedule a mentoring session to get help on time. Feel free to use the slack channel available.
- Deliverable 1 - (Due Date: Monday, October 18th)
- Deliverable 2 - (Due Date: Monday, October 25th)
- Deliverable 3 - (Due Date: Monday, November 1st)
- Deliverable 4 - (Due Date: Monday, November 8th)
- Final Deliverable - (Due Date: Monday, November 15th)
Related topics: React Fundamentals & CSS Styles in React
In this assignment, you will create the initial version of your Ecommerce Store. It should contain the following:
- Home Page (prototype)
- Fork this repo into your GitHub account
- Please make sure that your new repo is publicly accessible
- Create a new branch with the name “feat/deliverable1” derived from main on your forked repository
- Start working on the requirements specified below
-
Create the UI layout for your app, it should include the following elements:
- 1.1. A Header containing your Ecommerce Store logo/name, a search input, and a shopping cart icon. For now, all the elements in the header should be disabled, you only need to create the corresponding UI elements without the functionality.
- 1.2. The Content view corresponding to the section that will be rendered (in this case, the Home Page)
- 1.3. A Footer containing the message “Ecommerce created during Wizeline’s Academy React Bootcamp”
-
Create the Home Page including the following blocks:
- 2.1. A Slider to display the featured banners from this mock file
- 2.2. A Carousel or Grid of the product categories from this mock file
- 2.3. A Grid of Featured Products from this mock file. For each element on this grid, you should show at least the main image of the product, its name, category, and price.
- Try to keep the use of third-party libraries to the minimum, especially the ones related to the topics covered in our bootcamp. Please don’t use any UI library such as Bootstrap or Material UI, we want you to create all of your styles from scratch using the styling techniques learned.
- Please make sure that your UI is responsive and all the elements adapt to different screen sizes (Smartphone, Tablet, Desktop).
- Please make sure that no warnings or errors are logged in the browser console
- The Header is rendered correctly (25 points)
- The Featured Banners Slider is rendered correctly using the data from the mock file (20 points)
- The Categories Carousel/Grid is rendered correctly using the data from the mock file (20 points)
- The Featured Products Grid is rendered correctly using the data from the mock file (30 points)
- The Footer is rendered correctly (5 points)
- Unit Test to validate that the Ecommerce Store logo/name appears correctly in the Header. (10 points)
- Once you’ve covered all the requirements specified above and completed all the bullets on the Evaluation Criteria section, push your changes to your branch and open a PR that can be merged into your main branch of your own GitHub repository.
- Deploy your app into a hosting service such as Netlify, Firebase, Heroku, GitHub Pages, etc.
- Fill this Google Form to submit your project before October 18th at 8:00 AM (CST)
Related topics: React lifecycle & Hooks
In this assignment, you will continue working on your Ecommerce Store. It should contain the following:
- Home Page (prototype from previous deliverable)
- Product List Page (prototype)
- Merge your branch from the previous deliverable into main in your own GitHub repo
- Create a new branch with the name “feat/deliverable2” derived from main on your repo
- Read carefully all the instructions and notes for this deliverable
- Start working on the requirements specified below
- Add a button with the text “View all products” below your Featured Products Grid on the Home Page.
- Create a new component for your Product List that returns this React element for now:
<h1>This is the Product List Page</h1>
- Modify your App component to implement a conditional rendering logic to navigate through your pages. In this case, you will only need to be able to navigate from Home Page to Product List Page and from Product List Page to Home Page.
- Add an event handler to your “View all products” button so you can navigate to your Product List Page when you click on it.
- Test your conditional rendering logic to navigate to the Product List Page. After clicking on the “View all products” button, you should see the following message “This is the Product List Page” replacing the Home Page.
- Add an event handler to your Ecommerce logo in the header so you can navigate to your Home Page when you click on it.
- Test your conditional rendering logic to navigate to the Home Page. After clicking on the Ecommerce logo in the header, you should see your Home Page content, replacing the Product List Page.
- Modify your Product List Page component to contain the following blocks:
- 8.1. A Sidebar (left or right side, is up to you), it should contain a list of categories from this mock file. The elements in this list will work as filters for your products, so, you should render the name of each category and attach to it an empty handler for the onClick event.
- 8.2. A Grid of Products from this mock file. For each element on this grid, you should show at least the main image of the product, its name, category, and price.
- Add an event handler to the categories in your sidebar, so when you click on each of them, the products in the grid are filtered. The behavior of this filters should be the following:
- 9.1. By default each category filter should be disabled.
- 9.2. When you click on the category filter for the first time, that filter will be enabled and applied to the product grid.
- 9.3. When the filter is active/enabled, you should apply some styling to the selected category so it’s easier to distinguish between active and inactive states.
- 9.4. You can have multiple filters enabled at the same time, so when this happens, the products that will be shown in the grid should have at least one of the categories from the active filters.
- 9.5. To disable a filter, you will have to click on it and it should be removed from the active filters.
- Add pagination controls to the bottom of your list. For now, you just need to create the UI for these elements, you don’t need to implement the pagination logic on your grid yet.
- You won’t need to implement React Router library to navigate through your pages yet, you will only need to implement some conditional rendering logic to show the component for the page that you want to see.
- You should implement functional components with hooks
- Try to keep the use of third-party libraries to the minimum, especially the ones related to the topics covered in our bootcamp. Please don’t use any components library such as Bootstrap or Material UI.
- We want you to create all of your styles from scratch using the styling techniques learned, you can use any of the following styling approaches: Plain CSS with classnames, CSS pre-processors, CSS Modules, or CSS-in-JS (styled-components, emotion, or any other library), is totally up to you!
- Please make sure that your UI is responsive and all the elements adapt to different screen sizes (Smartphones, Tablet, and Desktop).
- Please make sure that no warnings or errors are logged in the browser console.
- Navigation from Home Page to Product List Page works correctly (15 points)
- Navigation from Product List Page to Home Page works correctly (15 points)
- The Sidebar with the list of categories is rendered correctly using the data from the mock file (10 points)
- The Products Grid is rendered correctly using the data from the mock file (25 points)
- Filtering behaviors are implemented correctly according to the requirements (30 points)
- Pagination controls are rendered correctly (5 points)
- Emulate loading state for the Products Grid. You should show a loader component immediately after you navigate to the Product List Page and 2 seconds after that, you should remove that loader and show all the products from the mock file (20 points)
- Once you’ve covered all the requirements specified above and completed all the bullets on the Evaluation Criteria section, push your changes to your branch and open a PR that can be merged into your main branch of your own GitHub repository.
- Deploy your app into a hosting service such as Netlify, Firebase, Heroku, GitHub Pages, etc.
- Fill this Google Form to submit your project before October 25th at 8:00 AM (CST)
Related topics: Fetching a Real API, React Router, Global State Management
In this assignment you will continue working on your Ecommerce Store. It should contain the following:
- Home Page (with API integration)
- Product List Page (with API integration)
- Product Detail Page (with API integration)
- Search Results Page (with API integration)
- Merge your branch from the previous deliverable into main in your own GitHub repo
- Create a new branch with the name “feat/deliverable3” derived from main on your repo
- Read carefully all the instructions and notes for this deliverable
- Start working on the requirements specified below
-
Refactor your App to use React Router to navigate across your pages. You should remove all the conditional rendering logic and update your “onClick” event handlers that you previously implemented so you can navigate through your pages using the React Router Link Component.
-
Update your Home Page according to the following requirements:
-
2.1. The route for this page should be / and /home
-
2.2. Refactor your Featured Banners Slider to fetch data from the API using this custom hook.
-
2.3. Refactor your Product Categories Carousel or Grid according to the following requirements:
-
2.3.1. Fetch data from this endpoint: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5Bat(document.type%2C%20%22category%22)%5D%5D&lang=en-us&pageSize=30
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
2.3.2. Each category should have a link to the Product List Page including a query param in the URL to filter the products by that category.
-
2.4. Refactor your Featured Products Grid according to the following requirements:
-
2.4.1. Fetch data from this endpoint: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5Bat(document.type%2C%20%22product%22)%5D%5D&q=%5B%5Bat(document.tags%2C%20%5B%22Featured%22%5D)%5D%5D&lang=en-us&pageSize=16
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
2.4.2. Each element on this grid should have at least the main image of the product, its name, category, price, “Add to cart” button, and a link to its detail page.
-
2.4.3. You should show 16 products maximum on this grid and it is not necessary to implement pagination controls.
- Update your Product List Page according to the following requirements:
-
3.1. The route for this page should be /products and /products?category={categorySlug}
-
3.2. Refactor your Product Categories Sidebar according to the following requirements:
-
3.2.1. Fetch data from this endpoint: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5Bat(document.type%2C%20%22category%22)%5D%5D&lang=en-us&pageSize=30
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
3.2.2. You should be able to filter your products by category according to the category filtering behavior from the previous deliverable.
-
3.2.3. If there is a filter applied, you should show a “Clear filters” button that will remove all the active filters and update the grid to show all the products.
-
3.3. Refactor your Products Grid according to the following requirements:
-
3.3.1. Fetch data from this endpoint: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5Bat(document.type%2C%20%22product%22)%5D%5D&lang=en-us&pageSize=12
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
3.3.2. Each element on this grid should have at least the main image of the product, its name, category, price, “Add to cart” button, and a link to its detail page.
-
3.3.3. Create the Pagination Controls dynamically, you should show 12 products maximum per page.
- Create the Product Detail Page according to the following requirements:
-
4.1. The route for this page should be /product/{productId}
-
4.2. Fetch data for the selected product from this endpoint: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5B%3Ad+%3D+at%28document.id%2C+%22{productId}%22%29+%5D%5D
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API and {productId} with the id of the selected product. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
4.3. This page should include the following blocks:
-
4.3.1. A Gallery to display the images of the selected product. You can use this library (or any other) and customize its appearance to match the look and feel of your application.
-
4.3.2. A Label to display the name of the selected product.
-
4.3.3. A Label to display the current price of the selected product.
-
4.3.4. A Label to display the SKU of the selected product.
-
4.3.5. A Label to display the category name of the selected product.
-
4.3.6. A List of Labels to display the tags of the selected product.
-
4.3.7. A Paragraph to display the description of the selected product.
-
4.3.8. A Number Input to select the number of items to be added to the cart.
-
4.3.9. An Add to Cart Button.
-
4.3.10. A Table or List to display the specs of the selected product.
- Create the Search Results Page according to the following requirements:
-
5.1. The route for this page should be /search?q={searchTerm}
-
5.2. You can consume this endpoint to get the products matching your search term: https://wizeline-academy.cdn.prismic.io/api/v2/documents/search?ref={apiRef}&q=%5B%5Bat(document.type%2C%20%22product%22)%5D%5D&q=%5B%5Bfulltext(document%2C%20%22{searchTerm}%22)%5D%5D&lang=en-us&pageSize=20
IMPORTANT: You have to replace the {apiRef} on the query params of the URL with the latest value for this particular API and {searchTerm} with the search term that the user entered. Please check the sample custom hook so you can implement something similar to fetch from this endpoint.
-
5.3. This page should contain the following blocks:
-
5.3.1. A List to display the products that match your search term. For each element on this grid, you should show at least the main image of the product, its name, category, price, short description, and “Add to Cart” button.
-
5.3.2. Pagination Controls created dynamically to switch between results pages in case there are more than 20 search results.
-
5.3.3. A Custom Message that will be rendered only when there are no results matching the searchTerm.
- Update your Header to include a search input and a button that after clicking on it, redirects to the Search Results Page for the search term that you entered.
- You should implement functional components with hooks.
- Try to keep the use of third-party libraries to the minimum, especially the ones related to the topics covered in our bootcamp. Please don’t use any components library such as Bootstrap or Material UI.
- We want you to create all of your styles from scratch using the styling techniques learned, you can use any of the following styling approaches: Plain CSS with classnames, CSS pre-processors, CSS Modules, or CSS-in-JS (styled-components, emotion, or any other library), is totally up to you!
- Please make sure that your UI is responsive and all the elements adapt to different screen sizes (Smartphones, Tablet, and Desktop).
- Please make sure that no warnings or errors are logged in the browser console.
- You don’t have to implement the “Add to cart” logic yet.
- If you want to dive deeper into how to consume the REST API please check the official documentation of the Prismic CMS which is the platform that we’re using for this project.
- Navigation to all pages (Home Page, Product Page, Product Detail Page, Search Results Page) works correctly using React Router (20 points)
- Featured Banners Slider, Product Categories Carousel/Grid, and Featured Products Grid on the Home Page are working correctly fetching data from the API (5 points)
- Product Category Sidebar on the Product List Page is filtering Products Grid correctly interacting with the API (25 points)
- Products List Grid is fetching data from the API and Pagination Controls are working correctly (15 points)
- Product Detail Page is fetching data correctly from the API for the selected product and all the required blocks are working properly (15 points)
- Search Results Page is connected to the search input in the header and is consuming the API to filter only the results that match the search term value from the query param (10 points)
- Pagination Controls and Custom Message in Search Results Page are generated dynamically and are working correctly (10 points)
- React Context and useReducer or Redux are implemented to manage the global state of your application (15 points)
- Abort Controller is implemented correctly for all your fetch requests (15 points)
- Loading indicator appears on all the components that consume an API (10 points)
- PropTypes are implemented correctly for all your components (10 points)
- Once you’ve covered all the requirements specified above and completed all the bullets on the Evaluation Criteria section, push your changes to your branch and open a PR that can be merged into your main branch of your own GitHub repository.
- Deploy your app into a hosting service such as Netlify, Firebase, Heroku, GitHub Pages, etc.
- Fill this Google Form to submit your project before November 1st at 8:00 AM (CST)
Related topics: React Router, Global State Management, Design Patterns, Best Practices & Performance Optimizations
In this assignment, you will continue working on your Ecommerce Store. It should contain the following:
- Product Detail Page (with “Add to Cart” functionality)
- Shopping Cart Page
- Checkout Page
- Merge your branch from the previous deliverable into main in your own GitHub repo
- Create a new branch with the name “feat/deliverable4” derived from main on your repo
- Read carefully all the instructions and notes for this deliverable
- Start working on the requirements specified below
- If you don’t have it already, add a “Shopping Cart Icon” to your header. You can create this icon as a separate component so you can add the logic to display a badge with the number of items that you have added to your cart. This icon will also serve as a link to navigate to the “Shopping Cart Page” after clicking on it.
- Modify the Product Detail Page according to the following requirements:
- 2.1. Implement the Add to Cart functionality for the selected product.
- 2.2. You should be able to add multiple items to your cart using the quantity selector. Please don’t forget to validate that you don’t exceed the stock units available for the selected product.
- 2.3. After clicking on the “Add to Cart” button the items should be added to your cart and the badge on the “Shopping Cart Icon” in the header should be updated to display the current quantity of items in the cart.
- 2.4. The “Add to Cart” button should be hidden or disabled when the stock units available for the selected product is zero. So you shouldn’t be able to add to cart a product that is not available in the stock.
- Create the Shopping Cart Page according to the following requirements:
- 3.1. The route for this page should be /cart
- 3.2. This page should contain a table to display the items added to the cart and you should build it considering the following:
- 3.2.1. There should be a row in this table per item/product in the cart.
- 3.2.2. Each row should show the main image of the product, its name, unit price, a quantity selector, subtotal (unit price x quantity) and a “remove from cart icon”.
- 3.2.3. At the bottom of the table there should be a label to display the cart total (sum of the subtotal’s column in the table) and a “Proceed to checkout” button that will serve as a link to navigate to the “Checkout Page” after clicking on it.
- 3.2.4. You should be able to modify the quantity of items that you want using the quantity selector. Please don’t forget to validate that you don’t exceed the stock units available for the selected product.
- 3.2.5. After updating the quantity the subtotal for the product and the cart total labels should be updated.
- Create the Checkout Page according to the following requirements:
- 4.1. The route for this page should be /checkout
- 4.2. This page should contain the following blocks:
- 4.2.1. A Form to capture the customer information for their order considering the following:
- 4.2.1.1. A text input to capture the name of the customer
- 4.2.1.2. A text input to capture the email of the customer
- 4.2.1.3. A text input to capture the post/zip code of the customer
- 4.2.1.4. A textarea to capture the order notes
- 4.2.2. An order summary table to display the items added to the cart and you should build it considering the following:
- 4.2.2.1. There should be a row in this table per item/product in the cart.
- 4.2.2.2. Each row should only show the name of the product, number of items added to cart and the subtotal (unit price x quantity).
- 4.2.2.3. At the bottom of the table there should be a label to display the cart total (sum of the subtotal’s column) and two buttons, one for “Place order” and the other for “Go back to cart”
- 4.2.3. You don’t have to implement the logic for the “Place order” button yet.
- 4.2.4. After clicking on the “Go back to cart” button, you should be able to navigate to the “Shopping Cart Page”.
- You should implement functional components with hooks.
- Try to keep the use of third-party libraries to the minimum, especially the ones related to the topics covered in our bootcamp. Please don’t use any components library such as Bootstrap or Material UI.
- We want you to create all of your styles from scratch using the styling techniques learned, you can use any of the following styling approaches: Plain CSS with classnames, CSS pre-processors, CSS Modules, or CSS-in-JS (styled-components, emotion, or any other library), is totally up to you!
- Please make sure that your UI is responsive and all the elements adapt to different screen sizes (Smartphones, Tablet, and Desktop).
- Please make sure that no warnings or errors are logged in the browser console.
- After clicking on the “Add to Cart” button on the Product Detail Page, the number of items selected are correctly added to the cart and the badge for the Shopping Cart Icon in the Header is updated correctly (25 points)
- The logic to update the quantity for a product on the “Shopping Cart Page” is implemented correctly (10 points)
- The logic to remove a product from the cart on the “Shopping Cart Page” is implemented correctly (10 points)
- The form on the “Checkout Page” is displayed correctly (10 points)
- The Order Summary table on the “Checkout Page” is displayed correctly (15 points)
- The “Add to Cart” functionality is implemented correctly using React Context or Redux across all pages (30 points)
- PropTypes are implemented correctly for all your components (10 points)
- Error Boundaries are applied correctly at least for 1 component within the app (15 points)
- useMemo and useCallback hooks are implemented correctly to improve performance if needed (20 points)
- Once you’ve covered all the requirements specified above and completed all the bullets on the Evaluation Criteria section, push your changes to your branch and open a PR that can be merged into your main branch of your own GitHub repository.
- Deploy your app into a hosting service such as Netlify, Firebase, Heroku, GitHub Pages, etc.
- Fill this Google Form to submit your project before November 8th at 8:00 AM (CST)
Related topics: Static Analysis Code, Jest and React Testing Library
In this final assignment, you will add automated tests to the current features that you already have for your E-commerce project.
- Merge your branch from the previous deliverable into main in your own GitHub repo
- Create a new branch with the name “feat/final-deliverable” derived from main on your repo
- Read carefully all the instructions and notes for this deliverable
- Start working on the requirements specified below
-
Please make sure that ESLint rules are applied to your code without errors or warnings. If you want to know more about setting up ESLint and Prettier in your “Create React App” project take a look at this article and this documentation link.
-
Add automated tests for the following scenarios in Home Page:
- 2.1. Featured Banners Slider is fetching and rendering data from the API
- 2.2. Categories Carousel/Grid is fetching and rendering data from the API
- 2.3. Featured Products Grid is fetching and rendering data from the API
- Add automated tests for the following scenarios in Product List Page:
- 3.1. Product Category Sidebar is fetching and rendering data from the API
- 3.2. Category links on Product Category Sidebar are filtering Products Grid correctly interacting with the API
- 3.3. Pagination Controls are generated correctly based on the number of results fetched from the API and the maximum number of products per page
- 3.4. Prev button is disabled when the user is on the first page
- 3.5. Next button is working as expected
- 3.6. Prev button is working as expected
- 3.7. Next button is disabled when the user is on the last page
- Add automated tests for the following scenarios in Product Detail Page:
- 4.1. Product Detail Page is fetching and rendering data from the API for a particular product.
- 4.2. Product Detail Page contains the following labels: name of the selected product, current price, SKU, category name, a list of tags, and description.
- 4.3. Product Detail Page contains a quantity selector and an “Add to Cart” button.
- 4.4. Validate that after clicking on the “Add to Cart” button, the number of items that are selected in quantity selector control are added to the cart.
- 4.5. Validate that the “Add to Cart” button is disabled when the stock units available for the selected product is zero.
- Add automated tests for the following scenarios in Search Results Page:
- 5.1. Validate that the list of results is rendering data according to the “searchTerm” provided.
- 5.2. Validate that an empty state is displayed when there are no results for the “searchTerm” provided.
- Add automated tests for the following scenarios in Shopping Cart Page:
- 6.1. Validate that an empty state is displayed when there are no items in the cart.
- 6.2. Validate that the list of products is shown when there are items in the cart. Each row should contain the main image of the product, its name, unit price, a quantity selector, subtotal and a “remove from cart icon”.
- 6.3. Validate that the cart total label displays the sum of the subtotals of all items in the cart.
- 6.4. Validate that you can update the quantity of items for a particular product in the cart. Don’t forget to validate that you don’t exceed the stock units available for the selected product.
- 6.5. Validate that you can remove a product from the cart after clicking on the “remove from cart icon”.
- IMPORTANT: Don’t consume the real APIs on the tests, instead, you can use the MSW (Mock Service Worker) library and please take a look at this article
- You must use Jest and React Testing Library for the tests
- Please avoid using snapshot tests
- Make sure that you are applying the best practices for testing behavior and not detailed implementations as the React Testing Library docs suggest
- Make sure to run your tests continuously and validate that all the test scenarios are passing successfully
- Test cases for Home Page (5 points)
- Test cases for Product List Page (20 points)
- Test cases for Product Detail Page (25 points)
- Test cases for Search Results Page (10 points)
- Test cases for Shopping Cart Page (40 points)
- Once you’ve covered all the requirements specified above and completed all the bullets on the Evaluation Criteria section, push your changes to your branch and open a PR that can be merged into your main branch of your own GitHub repository.
- Deploy your app into a hosting service such as Netlify, Firebase, Heroku, GitHub Pages, etc.
- Fill this Google Form to submit your project before November 15th at 8:00 AM (CST)