Instalación
- Clona el proyecto
git@github.com:oscaroceguera/MERN-kcal-private.git
- Frontend:
- Accede al front en la carpeta
cliente
- Instala dependecias del front con el comando
npm install
en la carpeta - Correr nuestra App con el comando
npm start
- Backend:
- Accede al back en la carpeta
server
- instala dependecias con
npm install
en la carpeta server - Correr nuestra API con el comando
npm start
Requisitos:
- Conocimiento de Javascript intermedio
- Conocimientos del controlador de versiones con GIT Usaremos la plataforma GitHub)
- Tener instalado GIT
- Tener instalado Nodejs
- Tener instalado NPM
- Tener instalado MongoDB
- Editor de código que desees
API (Backend):
Client (Frontend):
Utilizando la arquitectura MERN (Mongo, Express, React, Node), crear aplicación que guarde la cantidad de calorías consumidas por comida.
-
00_INICIO:
- Preparar ambiente para el API (nuestro primer endpoint):
- Instalar dependencias básicas para levantar un servicio con Nodejs usando Expressjs
- Preparar ambiente para el Cliente (hola mundo en reactjs)
- Instalar dependencias básicas para correr Reactjs usando Webpack
- Preparar ambiente para el API (nuestro primer endpoint):
-
01_ALTA_DE_COMIDA:
- [BACK] - Crear el modelo de tipo de comida:
- uuid: string
- value: string
- [BACK] - Crear controlador de alta de catalogo de tipo de comida
- [BACK] - Crear ruta de acceso a la alta de catalogo de tipo de comida (POST)
- [BACK] - Crear controlador de listado de catalogo de tipo de comida
- [BACK] - Crear ruta de acceso al listado de catalogo de tipo de comida (GET)
- [BACK] - Crear el modelo de tipo de alimento
- uuid: string
- label: string
- kcal: number
- type: String
- [BACK] - Crear controlador de alta de catalogo de tipo de alimento
- [BACK] - Crear ruta de acceso a la alta de catalogo de tipo de alimento (POST)
- [BACK] - Crear controlador de listado de catalogo de tipo de alimento
- [BACK] - Crear ruta de acceso al listado de catalogo de tipo de alimento (GET)
- [BACK] - Crear Modelo de comida:
- uuid: String
- meal: String
- date: date
- foods: referencia al catalogo de tipo de comida
- mealType: referencia al catalogo de tipo de alimento
- [BACK] - Crear controlador de alta de comida
- [BACK] - Crear ruta de acceso para alta de comida (POST)
- [FRONT] - Input de texto para introducir nombre de la comida (Pozole, Menudo, Ceviche, etc).
- [FRONT] - Dropdown que consultara al catalogo de tipo de comida (Desayuno, Comida, Colación, Cena).
- [FRONT] - Datepicker que registra la fecha de consumo.
- [FRONT] - Autocomplete de alimentos utilizados, el cual consultara al catalogo de alimentos (pollo, cebolla, tomates, etc):
- Autocomplete component:
https://gist.github.com/oscaroceguera/621a08f64e1b391059d5a0fc6bff1ccd
- Autocomplete functions
https://gist.github.com/oscaroceguera/bdf5512e13b399e9b2042dad7078c791
- Autocomplete component:
- [FRONT] - Guardar comida.
- [BACK] - Crear el modelo de tipo de comida:
-
02_LISTADO_COMIDAS:
- [BACK] - Crear controlador de listado de comidas
- [BACK] - Crear ruta de acceso de listado de comidas (GET)
- [FRONT] - Listado de comidas
-
03_ACTUALIZAR_COMIDA:
- [BACK] - Crear controlador para obtener el de detalle de comida
- [BACK] - Crear ruta de acceso para obtener el detalle de comida (GET)
- [FRONT] - Mostrar de detalle de comida
- [BACK] - Crear controlador para actualizar comida
- [BACK] - Crear ruta para acceder a actualizar comida (PATCH)
- [FRONT] - Actualizar comida
-
04_ELIMINAR_COMIDA:
- [BACK] - Crear controlador para elimiar comida
- [BACK] - Crear url para acceder a elimiar comida (DELETE)
- [FRONT] - Eliminar comida
-
05_SUMA_DE_KCAL:
- [BACK] - Crear controlador para obtener la suma de calorias Por mes
- [BACK] - Crear ruta para obtener la suma de calorias Por mes (GET)
- [FRONT] - Mostrar suma de calorias por mes
- [BACK] - Crear controlador para obtener la suma de calorias Por mes
- [BACK] - Crear ruta para obtener la suma de calorias Por año (GET)
- [FRONT] - Mostrar suma de calorias por año
- [BACK] - Crear controlador para obtener la suma de calorias Por día
- [BACK] - Crear ruta para obtener la suma de calorias Por día (GET)
- [FRONT] - Mostrar suma de calorias por día
-
5.1_TDD_BACK_BONUS
- [BACK] - TDD
-
5.2_TDD_FRONT_BONUS
- [FRONT] - TDD
-
5.3_E2E_FRONT_BONUS
- [FRONT] - E2E
-
06_SESION_USUARIOS
-
07_DEPLOY_PRODUCCION:
- [BACK] - Heroku
- [BACK] - AWS EC2
- [FRONT] - Netlifly
- [FRONT] - AWS S3