Code Monkey home page Code Monkey logo

rappi-test's Introduction

Rappi Test

Front end Rappi Test using React + Redux

Frontend Developer Challenge

Requerimientos

Tiendas “El Baratón” necesita un e-commerce para expandir sus servicios, para eso don Pepe (propietario de la tienda) ha provisto de los siguientes requerimientos:

  • La tienda debe mostrar categorías las cuales están conformadas por subniveles, éstos subniveles a su vez pueden tener más subniveles anidados, se debe hacer un menú donde aparezcan categorías y subniveles de forma anidada. Ejemplo:

    • Categoría licores
    • subnivel vinos
      • subnivel vinos tintos
      • subnivel vinos blancos
  • Los productos tienen un identificador principal y un identificador de subnivel, esto quiere decir que un producto sólo debe ser mostrado en su subnivel correspondiente.

  • Los productos deben filtrarse por: disponibilidad, rango de precios, cantidad en stock.

  • Los productos deben poder ordenarse por precio, disponibilidad y cantidad.

  • Se debe crear un carrito de compras donde los usuarios puedan agregar, editar cantidad y eliminar un producto.

  • Los productos deben permanecer en el carrito si el usuario cierra y abre la página, solo deben ser borrados si el usuario realiza la compra.

  • Un subnivel final es aquel que no tiene más subniveles, en éste caso debe aparecer una caja de texto que permita realizar búsquedas de productos por nombre en dichos subniveles.

  • Además, el ecommerce debe ser responsive.

Table of Contents

Setting up

Para este test se decidio utilizar ReactJS + Redux como Librerias principales de JS. Se utilizo la version 2 de create-react-app.

La persistencia de datos para el carrito de compras, fue manejado con localStorage.

La estructura del proyecto es la creada mediante create-react-app , especificada en el siguiente link.

Se crearon tests para probar el funcionamiento y la integracion de los componentes de la aplicacion usando Jest y Enzyme.

Steps

Clonar este repositorio (git clone [email protected]:matextrem/Rappi-test.git)

NODE_VERSION : 8.12.0

 cd Rappi-test
 npm install
 npm run build
 npm run start  //Esto abrira la aplicacion en http://localhost:3000

Developed with

  • ReactJS - Libreria utilizada para el desarrollo del frontend.
  • Redux - Libreria utilizada para el manejo de los estados de la aplicación y la persistencia del mismo en localStorage.
  • React Semantic-UI - User interface utilizada para el styling de la aplicación.
  • Jest - Herramienta utilizada para los tests.

Authors

  • Matias Dastugue

rappi-test's People

Contributors

matextrem avatar

Watchers

Carlos Garcia avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.