Skip to content

jbobd/ml-test

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Test de mercadolibre

Esta app es un mini clon de Mercado Libre. Con funcionalidad de búsqueda y vista de detalle de productos Para realizarla utilicé el siguiente stack:

Cliente:

  • js
  • React w/ Hooks
  • scss

Servidor:

  • Node.js
  • Express

Para poder ejecutarlo, realizar lo siguiente:

Instalación

Clonar el repositorio y luego realizar lo siguiente:

server

cd server 
npm install 
npm run dev 

client

cd client
npm install
npm start 

La aplicación ya debería estar corriendo en http://localhost:3000/

Explicación

  • Contiene dos componentes principales, el navbar que siempre se muestra, y el pageContent, que renderiza ,matcheando por url, el componente de resultados de búsqueda o el de detalle de producto.

  • Al enviar un input en el searchbar, hago una búsqueda en mi endpoint /items/q , guardo el resultado en el state y seteo mi path location en /items/q. El componente pageContent mostrará entonces la vista de resultados de búsqueda con el resultado obtenido

  • Cada uno de estos resultados tendrá un link a /items/{id}, al clickearse la imagen o el título, seteo el path location en /items/{id}, y pageContent renderizará la vista de detalle de producto.

  • Al montarse el componente de detalle de producto, toma el id desde el path location, y llama a mi endpoint /items para obtener los datos del mismo. De esta forma también funciona al ingresar directamente un id de producto en la url.

Known Issues:

  • Al seleccionar un nuevo item, muestra el producto anterior mientras carga el nuevo.

TO_DO's:

  • Mejorar scss, implementar variables.
  • Añadir jest para unit testing.
  • Mejoras de SEO / usabilidad
  • Añadir vista de producto no encontrado.

About

test de mercadolibre

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published