Skip to content

Latest commit

 

History

History
102 lines (71 loc) · 2.6 KB

README.md

File metadata and controls

102 lines (71 loc) · 2.6 KB

PokeStore

This project is my rendition of the B2W Challenge. Its objective is to create an e-commerce storefront for pokémon.

Live demo: https://pokestore-guswillemann.vercel.app/


Tools


The Challenge

Most of the pokémon data used in the project are available on the pokéApi. The missing data (needed for this project) was the pokémon's price, so I randomly generated it after fetching the data from the API.

The challenge requirements:

  • Products list
  • User cart
  • Cart summary
  • Two storefronts for different Pokémon types.

Extra features:

  • Search bar to filter Pokémon
  • Checkout button, restarting the purchase data
  • Checkout Modal.
  • Save the cart data so it will not be lost on a page refresh.

B2W provides a wireframe for the storefront:

storefront wireframe

Home

Since the challenge objective was to create multiple storefronts, I used the home page to display the available stores.

It has stores for Fire, Grass, Rock, and Water Pokémon:

Home page

Store pages

The store pages are implementations of the provided wireframe.

Desktop

Desktop storefronts

Mobile

Mobile storefronts

On mobile, the user cart is a collapsable panel.

mobile cart example

Development Highlights

Storefronts:

The storefronts follow the same layout. So I created the StoreScreen Component to handle the creation of the pages:

export default function StorePage({ products, cartListCookie }) {
  return (
    <StoreScreen
      products={products}
      cartListCookie={cartListCookie}
      storeType={storeType}
      theme={theme}
    />
  );
}

Component props:

  • theme: an object with the theme values;
  • products: an array with the pokémon data;
  • cardListCookie: the cookie with the user cart data;
  • storeType: the name of the store (based on the pokémon types).

User Cart

The user cart data is saved in cookies for each path (e.g. '/fire'; '/grass'; etc.), thus having a unique cart for each storefront.