Skip to content

Repositorio destinado al desarrollo y presentación del proyecto integrador del cuarto semestre de la Tecnicatura Universitaria en Programación, UTN FRSR.

Notifications You must be signed in to change notification settings

CodeSystem2022/Proyecto-Integrador-Bestias-Binarias

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ecommerce con React, Firebase, Context API y Hooks

Este proyecto fue realizado como proyecto final para la Tecnicatura Universitaria en Programación de la UTN FRSR. El mismo consiste en un ecommerce de una hamburguesería, donde se pueden ver los productos, agregarlos al carrito y realizar la compra.

Para la persistencia de datos (Productos, Categorias, Mensajes del cliente y Ordenes de compra) se utilizó Firestore de Firebase, ya que es una base de datos en tiempo real, y está disponible dentro de la capa gratuita de Google Cloud Platform. Si desea ejecutar el proyecto, es necesario que cree un proyecto en Firebase y configure las variables de entorno en el archivo .env o en el Dockerfile.

Para el manejo de estado se utilizó Context API y Hooks. Se crearon contextos para el manejo de los productos, categorías, mensajes y ordenes de compra. En cada uno de ellos se crearon los métodos necesarios para realizar las operaciones de CRUD. Para el manejo de los estados de los componentes se utilizaron Hooks como useState, useEffect, useContext, etc. Y, además, se crearon hooks personalizados para el manejo de los estados del carrito y de los productos recibidos desde firestore.

Se eligió trabajar con Javascript y React debido a que es una de las tecnologías más utilizadas en el mercado laboral actualmente. Además, se eligió trabajar con Bootstrap para el diseño de la aplicación ya que permite un despliegue rápido y sencillo de los componentes.

El proyecto cuenta con un archivo Dockerfile para la creación de la imagen y el contenedor de Docker. Para ejecutar el proyecto con Docker, debe configurar las variables de entorno en el archivo Dockerfile.

Tabla de contenidos

Demo

Si desea ver el proyecto funcionando, puede hacerlo visitando este enlace, que lo llevará a un deploy realizado en la plataforma Vercel.app, debido a que provee una capa gratuita de implementación de proyectos y un servicio de entrega continua al integrarse con este repositorio de Github.

Instalación con Dockerfile

Clonar el repositorio

git clone https://github.com/CodeSystem2022/Proyecto-Integrador-Bestias-Binarias.git

Configurar dockerfile

Debe inscribir las variables de entorno de Firestore en el archivo Dockerfile:

REACT_APP_API_KEY=
REACT_APP_AUTH_DOMAIN=
REACT_APP_PROJECT_ID=
REACT_APP_STORAGE_BUCKET=
REACT_APP_MESSAGING_SENDER_ID=
REACT_APP_APP_ID=

Crear la imagen

docker build -t ecommerce-react .

Correr el contenedor

docker run -p 3000:3000 ecommerce-react

Instalación sin Dockerfile

Clonar el repositorio

git clone

Instalar dependencias

npm install

Configurar variables de entorno

Debe inscribir las variables de entorno de Firestore en el archivo .env:

REACT_APP_API_KEY=
REACT_APP_AUTH_DOMAIN=
REACT_APP_PROJECT_ID=
REACT_APP_STORAGE_BUCKET=
REACT_APP_MESSAGING_SENDER_ID=
REACT_APP_APP_ID=

Iniciar el proyecto

npm start

Tecnologías utilizadas

  • React
  • Firebase
  • Context API
  • Hooks
  • Bootstrap
  • React Router
  • React Icons
  • SweetAlert2
  • React Spinners
  • Formik
  • Yup

Autores

About

Repositorio destinado al desarrollo y presentación del proyecto integrador del cuarto semestre de la Tecnicatura Universitaria en Programación, UTN FRSR.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 84.2%
  • CSS 12.3%
  • HTML 2.5%
  • Dockerfile 1.0%