Skip to content

LiamMarega/DogAppDeploy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

# Individual Project - Henry Dogs

## Objetivos del Proyecto - Construir una App utlizando React, Redux, Node y Sequelize. - Afirmar y conectar los conceptos aprendidos en la carrera. - Aprender mejores prácticas. - Aprender y practicar el workflow de GIT. - Usar y practicar testing. ## Horarios y Fechas El proyecto tendrá una duración máxima de tres semanas. En el caso de que completan todas las tareas antes de dicho lapso podrán avisar a su Instructor para coordinar una fecha de presentación del trabajo (DEMO). ## Comenzando 1. Forkear el repositorio para tener una copia del mismo en sus cuentas 2. Clonar el repositorio en sus computadoras para comenzar a trabajar Tendrán un `boilerplate` con la estructura general tanto del servidor como de cliente. __IMPORTANTE:__ Es necesario contar minimamente con la última versión estable de Node y NPM. Asegurarse de contar con ella para poder instalar correctamente las dependecias necesarias para correr el proyecto. Actualmente las versiónes necesarias son: * __Node__: 12.18.3 o mayor * __NPM__: 6.14.16 o mayor Para verificar que versión tienen instalada: > node -v > > npm -v ## BoilerPlate El boilerplate cuenta con dos carpetas: `api` y `client`. En estas carpetas estará el código del back-end y el front-end respectivamente. En `api` crear un archivo llamado: `.env` que tenga la siguiente forma: ``` DB_USER=usuariodepostgres DB_PASSWORD=passwordDePostgres DB_HOST=localhost ``` Reemplazar `usuariodepostgres` y `passwordDePostgres` con tus propias credenciales para conectarte a postgres. Este archivo va ser ignorado en la subida a github, ya que contiene información sensible (las credenciales). Adicionalmente será necesario que creen desde psql una base de datos llamada `dogs` El contenido de `client` fue creado usando: Create React App. ## Enunciado La idea general es crear una aplicación en la cual se puedan ver distintas razas de perro junto con información relevante de las mismas utilizando la api externa [the dog api](https://thedogapi.com/) y a partir de ella poder, entre otras cosas: - Buscar perros - Filtrarlos / Ordenarlos - Agregar nuevos perros __IMPORTANTE__: Para poder utilizar esta API externa es necesario crearse una cuenta para obtener una API Key que luego debera ser incluida en todos los request que hagamos a rawg simplemente agregando `?api_key={YOUR_API_KEY}` al final de cada endpoint. Agregar la clave en el archivo `.env` para que la misma no se suba al repositorio por cuestiones de seguridad y utilizarla desde allí. __IMPORTANTE__: Para las funcionalidades de filtrado y ordenamiento NO pueden utilizar los endpoints de la API externa que ya devuelven los resultados filtrados u ordenados sino que deben realizarlo ustedes mismos. En particular alguno de los ordenamientos o filtrados debe si o si realizarse desde el frontend. ### Únicos Endpoints/Flags que pueden utilizar - GET https://api.thedogapi.com/v1/breeds - GET https://api.thedogapi.com/v1/breeds/search?q={raza_perro} ### Requerimientos mínimos: A continuación se detallaran los requerimientos mínimos para la aprobación del proyecto individial. Aquellos que deseen agregar más funcionalidades podrán hacerlo. En cuanto al diseño visual no va a haber wireframes ni prototipos prefijados sino que tendrán libertad de hacerlo a su gusto pero tienen que aplicar los conocimientos de estilos vistos en el curso para que quede agradable a la vista. __IMPORTANTE__: No se permitirá utilizar librerías externas para aplicar estilos a la aplicación. Tendrán que utilizar CSS con algunas de las opciones que vimos en dicha clase (CSS puro, CSS Modules o Styled Components) #### Tecnologías necesarias: - [ ] React - [ ] Redux - [ ] Express - [ ] Sequelize - Postgres #### Frontend Se debe desarrollar una aplicación de React/Redux que contenga las siguientes pantallas/rutas. __Pagina inicial__: deben armar una landing page con - [ ] Alguna imagen de fondo representativa al proyecto - [ ] Botón para ingresar al home (`Ruta principal`) __Ruta principal__: debe contener - [ ] Input de búsqueda para encontrar razas de perros por nombre - [ ] Área donde se verá el listado de razas de perros. Deberá mostrar su: - Imagen - Nombre - Temperamento - Peso - [ ] Botones/Opciones para filtrar por: - Temperamento - Raza existente (es decir las que vienen de la API) o agregada por nosotros (creadas mediante el form) - [ ] Botones/Opciones para ordenar tanto ascendentemente como descendentemente las razas de perro por: - Orden alfabético - Peso - [ ] Paginado para ir buscando y mostrando las siguientes razas, mostrando 8 razas por página. __IMPORTANTE__: Dentro de la Ruta Principal se deben mostrar tanto las razas de perros traidas desde la API como así también las de la base de datos, pero NO está permitido almacenar en la base de datos las razas de perros de la API sino que solamente se pueden guardar aquellas creadas desde el form. __Ruta de detalle de raza de perro__: debe contener - [ ] Los campos mostrados en la ruta principal para cada raza (imagen, nombre y temperamento) - [ ] Altura - [ ] Peso - [ ] Años de vida __Ruta de creación de raza de perro__: debe contener - [ ] Un formulario __controlado__ con los siguientes campos - Nombre - Altura (Diferenciar entre altura mínima y máxima) - Peso (Diferenciar entre peso mínimo y máximo) - Años de vida - [ ] Posibilidad de seleccionar/agregar uno o más temperamentos - [ ] Botón/Opción para crear una nueva raza de perro #### Base de datos El modelo de la base de datos deberá tener las siguientes entidades (Aquellas propiedades marcadas con asterísco deben ser obligatorias): - [ ] Raza con las siguientes propiedades: - ID * - Nombre * - Altura * - Peso * - Años de vida - [ ] Temperamento con las siguientes propiedades: - ID - Nombre La relación entre ambas entidades debe ser de muchos a muchos ya que una raza de perro puede tener varios "temperamentos" en simultaneo y, a su vez, un "temperamento" puede corresponder a múltiples razas de perro distintas. Por ejemplo la raza `pug` es docil, inteligente y sociable (entre otras). Pero a su vez existen otras razas de perro que también son sociables o inteligentes. __IMPORTANTE__: Pensar como modelar los IDs de las razas de perros en la base de datos. Existen distintas formas correctas de hacerlo pero tener en cuenta que cuando hagamos click en alguna, esta puede provenir de la API o de la Base de Datos por lo que cuando muestre su detalle no debería haber ambigüedad en cual se debería mostrar. Por ejemplo si en la API la raza `Pug` tiene id = 1 y en nuestra base de datos creamos una nueva raza `Henry Pug` con id = 1, ver la forma de diferenciarlas cuando querramos acceder al detalle de la misma. #### Backend Se debe desarrollar un servidor en Node/Express con las siguientes rutas: __IMPORTANTE__: No está permitido utilizar los filtrados, ordenamientos y paginados brindados por la API externa, todas estas funcionalidades tienen que implementarlas ustedes. - [ ] __GET /dogs__: - Obtener un listado de las razas de perro - Debe devolver solo los datos necesarios para la ruta principal - [ ] __GET /dogs?name="..."__: - Obtener un listado de las razas de perro que contengan la palabra ingresada como query parameter - Si no existe ninguna raza de perro mostrar un mensaje adecuado - [ ] __GET /dogs/{idRaza}__: - Obtener el detalle de una raza de perro en particular - Debe traer solo los datos pedidos en la ruta de detalle de raza de perro - Incluir los temperamentos asociados - [ ] __GET /temperament__: - Obtener todos los temperamentos posibles - En una primera instancia deberán obtenerlos desde la API externa y guardarlos en su propia base de datos y luego ya utilizarlos desde allí - [ ] __POST /dog__: - Recibe los datos recolectados desde el formulario controlado de la ruta de creación de raza de perro por body - Crea una raza de perro en la base de datos #### Testing - [ ] Al menos tener un componente del frontend con sus tests respectivos - [ ] Al menos tener una ruta del backend con sus tests respectivos - [ ] Al menos tener un modelo de la base de datos con sus tests respectivos # DogAppDeploy # DogAppDeploy

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published