This is a solution to the E-commerce product page challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.
Note: Delete this note and update the table of contents based on what sections you keep.
Users should be able to:
- View the optimal layout for the site depending on their device's screen size
- See hover states for all interactive elements on the page
- Open a lightbox gallery by clicking on the large product image
- Switch the large product image by clicking on the small thumbnail images
- Add items to the cart
- View the cart and remove items from it
- Semantic HTML5 markup
- CSS custom properties
- Flexbox
- CSS Grid
- Mobile-first workflow
- Tailwindcss
- lightbox
- React - JS library
- Lightbox - React framework
- Tailwind css - For styles
During the course of this project, i got more reinforcement on the use of tailwindCss in projects and some quick hacks. Important to note is also passing functions about, and the use of memo to limit renders based on user calculations. in addition, i also got more practice with creating and consuming a context, and i gave usereducer a try, although i had to strip it off because it didnt feel like it belonged.
updating quantity state based on action,surrogate reducer?
switch (action) {
case "add":
setQuantity(quantity + 1)
break;
case "minus":
setQuantity(quantity - 1)
break;
default:
break;
}
context setup
export const productContext = createContext()
export function ProductProvider({children}) {
let [cartItem,setCartItem] = useState([])
let [toggleNav,setToggleNav] = useState(false)
let products = [
{}
]
function updateCart(cartUpdate,id){
setCartItem([ cartUpdate])
}
function deleteItem(id){
let updatedCart = cartItem.filter(item => item.id !== id );
setCartItem(updatedCart)
}
return (
<productContext.Provider value={{products,updateCart,deleteItem,cartItem,toggleNav,setToggleNav}}>
{children}
</productContext.Provider>
)
}
For my continued developement, i do hope to have down the basics of useReducer, now that i have a clear understanding of context and the plain js reducer.
- React Lightbox - React lightbox is a tool that does as its name suggests, its used to create details on images
- Hero Icon - This is an amazing article which helped me finally understand XYZ. I'd recommend it to anyone still learning this concept.
- Website - Paschal
- Frontend Mentor - @haybukarh
- Twitter - [@haybukarh](https://twitter.com/haybukarh