Skip to content

Latest commit

 

History

History
767 lines (594 loc) · 35.4 KB

README.md

File metadata and controls

767 lines (594 loc) · 35.4 KB

POKEMON

Índice


1. Resumen del Proyecto

Se construyó una aplicación web que le permitirá a los usuarios conocer sobre el mundo pokemon. La aplicación le permitirá conocer a detalle a los pokemons y conocer a aquellos que pueden usar en batallas pokemon.

Final 1

Final 2

Final 3

2. Definición del Producto

2.1. Usuarios

  • Adolescentes y jóvenes bilingues de género indistinto, que desean participar en su primera batalla pokemon. Para ello, quieren conocer a detalle sobre cada pokemon (peso, tamaño, elemento, huevo, elementos a los que presenta resistencia, elementos a los que es débil, movimientos rápidos, ataques especiales y línea evolutiva), quieren conocer los pokemons que son resistentes a más elementos y conocer a aquellos pokemons que gasten menos energía por segundo (EPS) en movimientos para que puedan ganar una batalla pokemon.

2.2. Objetivos del Proyecto

  • El objetivo de la aplicación web es que los usuarios puedan visualizar todos los pokemons y sus características para así reconocer a los que mejor podrían usar para una batalla y ser un mejor jugador de Pokemon.

2.3. Problemas que soluciona

  • Mostrar 251 pokemons en la pagina principal y que cada uno muestre tres características principales (imagen, número de pokedex, nombre y elemento)
  • Mostrar información a detalle de cada pokemon
  • Filtrar por liga: Kanto y Johto
  • Filtrar pokemons por elemento al que pertenece
  • Filtrar pokemons por elemento al que presenta resistencia
  • Ordenar pokemons de mayor nivel de resistencia a menor nivel de resistencia
  • Ordenar pokemons de menor nivel de resistencia a mayor nivel de resistencia
  • Ordenar pokemons alfabéticamente de A-Z
  • Ordenar pokemons alfabéticamente de Z-A
  • Ordenar pokemons por evolución
  • Calcular EPS (energía por movimiento) de cada movimiento de un pokemon
  • Buscar por nombre a un pokemon

3. Historias de Usuario

HU1: Bienvenida al usuario

Historia de Usuario

  • Yo como usuario quiero recibir la bienvenida para saber de que trata la página.

Criterios de Aceptación

  • Se dará una bienvenida al usuario, informando sobre el tema de la página e invitando a ingresar.
  • El usuario podrá acceder al hacer click en el botón de Inicio

Definición de Terminado

  • Responsive web design
  • Eslint con 0 errores
  • Desplegar en gh-pages

HU2: Mostrar todos los pokemones

Historia de usuario

Yo como: usuario Quiero: Ver todos los pokemons Para: Tener referencia de los pokemones disponibles. (imagen y nombre)

Criterios de Aceptación

  • El usuario podrá visualizar a todos los pokemones con su respectiva imagen, nombre y número de pokedex.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones y que salgan sin error

HU3: Mostrar los datos a detalle de cada pokemon

Historia de usuario
  • Yo como usuario quiero obtener información a detalle de cada pokemon al hacer click en su imagen. para conocer sobre el peso, altura, huevo, caramelo, tipo, resistencia, debilidad, movimientos y evoluciones de cada pokemón.

Criterios de Aceptación

  • El usuario visualiza la información detallada del pokemón en una interfaz superpuesta.
  • El usuario puede visualizar las evoluciones del pokemón y también puede acceder a su información a detalle.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU4: Un buscador para filtrar el pokemon por nombre.

Historia de usuario

  • Yo como usuario quiero buscar un pokemon por su nombre para Facilitar la búsqueda.

Criterios de aceptación

  • El usuario observa en la barra de navegación al lado derecho un buscador
  • El usuario escribe el nombre del pokemon que desea
  • El usuario escribe el nombre del pokemonse y este se autocompleta
  • El usuario obtiene al pokemon buscado

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU5: Filtrar los pokemones por tipo de resistencia

Historia de Usuario

  • Yo como usuario, quiero obtener los pokemones resistentes a un determinado tipo de elemento para elegir a un pokemon para un combate.

Criterios de Aceptación

  • El usuario observa un select en la parte superior izquierda
  • El usuario observa las opciones al tipo de resistencia en el select, y puede hacer click en un de ellos para obtener el de su preferencia.
  • El usuario observa los pokemons del tipo seleccionado.
Definición de terminado
  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones y que salgan sin error
  • Desplegar en gh-pages

HU6: Ordenar los pokemones por nivel de resistencia.

Historia de Usuario
  • Yo como usuario, quiero ordenar los pokemones de los más resistentes a los menos resistentes y viceversa para poder elegir a un pokemon fuerte para un combate.

Criterios de Aceptación

  • El usuario observa un select en la parte superior derecha de los pokemons.
  • El usuario encuentra en el select las opciones ordenar por mayor resistencia y ordenar por menor resistencia.
  • El usuario haciendo click en una de las opciones, obtiene el resultado.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU7: Obtener la energía por movimiento de cada Pokemon.

Historia de Usuario

  • Yo como usuario, quiero obtener la energía por movimiento de los pokemons para elegir a aquellos que no gasten mucha energía en una batalla.

Criterios de Aceptación

  • El usuario al hacer click en la imagen de un pokemon observa en la sección de movimientos un botón para calcular la energía por movimiento.
  • El usuario al hacer click en el botón Calcular EPS obtiene lo solicitado de cada movimiento.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU8: Filtrar pokemons por Liga

Historia de Usuario

  • Yo como usuario quiero filtrar pokemons por liga para diferenciar aquellos que son de liga kanto y liga johto

Criterios de Aceptación

  • El usuario observa en el navegador la opción liga y al hacer click se despliega opción kanto y johto
  • El usuario al hacer click en las opciones, filtra los correspondientes a cada liga.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU9: Ordenar pokemons alfabeticamente

Historia de Usuario

  • Yo como usuario quiero ordenar alfabéticamente de la A-Z y de la Z-A a los pokemons para ubicarlos rápido si no sé cómo se escribe el nombre completo.

Criterios de Aceptación

  • El usuario observa un select en la parte superior derecha y tiene las opciones ordenar de la A-Z y de Z-A
  • El usuario al hacer click en las opciones, ordena de manera que corresponda a la opción seleccionada.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU10: Filtrar pokemons por tipo de elemento

Historia de Usuario

  • Yo como usuario quiero filtrar pokemons por tipo de elemento para conocer aquellos que son del elemento agua, aire, fuego, etc.

Criterios de Aceptación

  • El usuario observa en el navegador la opción tipo y al hacer click se despliega las opciones de los diferentes tipos de elementos
  • El usuario al hacer click en las opciones, filtra los correspondientes a cada tipo de elemento.

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores
  • Testear las funciones

HU11: Ordenar pokemons por evolución

Historia de Usuario

  • Yo como usuario quiero ordenar pokemons por evolución para conocer su cronología evolutiva

Criterios de Aceptación

  • El usuario observa en la parte superior derecha el select "ordenar por" y encuentra la opción ordenar por evolución
  • El usuario al hacer click en la opción, los pokemons se ordenan por evolución

Definición de terminado

  • Responsive web design
  • Eslint con 0 errores

4. Diseño UX

4.1. Prototipo de baja fidelidad/Feedback recibido

HU1

HU1

  • El texto de Bienvenida tendrá que ser un resumen preciso sobre la página, para no aburrir al usuario. Y los colores deben contrastarse unos a otros para que los elementos no se pierdan.
HU2

HU2

  • Al mostrar toda la lista de pokemones, solo mostrar 2 ó 3 detalles principales, todas sus características a detalle se mostrarán en un modal al hacer click en cada pokemon.
HU3

HU3

  • El usuario al hacer click en el pokemon encuentra información a detalle del pokemon por secciones. El usuario señala que se debe resaltar los títulos de cada sección.
HU4

HU4

  • El usuario no tiene problema para encontrar el buscador, y le resulta amigable que al ir escribiendo una letra se vaya mostrando coincidencias. El usuario desea que al hacer click en el pokemon se muestre directamente el modal con la información detallada de este.
HU5

HU5

  • El usuario encuentra redundante filtrar por resistencia desde la opción del menu navegador y del select. El usuario menciona que el filtrado en el select le parece suficiente. Luego, observa fácilmente dónde puede filtrar los pokemones por tipo de resistencia y hacer el filtrado correspondiente (agua, fuego, etc.)
HU6

HU6

  • El usuario fácilmente puede ordenar por nivel de resistencia a sus pokemones y le resulta muy útil para reconocer los pokemons que resisten a más elementos.
HU7

HU7

  • Al usuario no le queda claro para qué bloque de movimientos se hará el calculo de EPS. Así que, recomienda fijar el botón en un lugar donde sea entendible que al hacer el calculo se mostrara el EPS de todos los movimientos mostrados.
HU8

HU8

  • El usuario realiza fácilmente la tarea de filtrar por liga a los pokemons.
HU9

HU9

  • El usuario ordena alfabéticamente de A-Z y Z-A los pokemons sin ningún problema.
HU10

HU10

  • El usuario logra fácilmente filtrar a los pokemons por tipo de elemento
HU11

HU11

  • El usuario realiza fácilmente la tarea de ordenar los pokemons por evolución

4.2. Prototipo de alta fidelidad para móvil y desktop

Inicio

Pagina principal

Modal

Data Lovers

Índice


1. Preámbulo

Según Forbes, el 90% de la data que existe hoy ha sido creada durante los últimos dos años. Cada día generamos 2.5 millones de terabytes de datos, una cifra sin precedentes.

No obstante, los datos por sí mismos son de poca utilidad. Para que esas grandes cantidades de datos se conviertan en información fácil de leer para los usuarios, necesitamos entender y procesar estos datos. Una manera simple de hacerlo es creando interfaces y visualizaciones.

En la siguiente imagen, podrás ver cómo con la data que que se ve en la parte izquierda se puede construir una interfaz amigable y entendible por el usuario al lado derecho.

json-interfaz

2. Resumen del proyecto

En este proyecto construirás una página web para visualizar un conjunto (set) de datos que se adecúe a lo que descubras que tu usuario necesita.

Como entregable final tendrás una página web que permita visualizar la data, filtrarla, ordenarla y hacer algún cálculo agregado. Con cálculo agregado nos referimos a distintos cálculos que puedes hacer con la data para mostrar información aún más relevante para los usuarios (promedio, el valor máximo o mínimo, etc).

Esta vez te proponemos una serie de datos de diferentes temáticas para que explores y decidas con qué temática te interesa trabajar. Hemos elegido específicamente estos sets de datos porque creemos que se adecúan bien a esta etapa de tu aprendizaje.

Una vez que definas tu área de interés, buscar entender quién es tu usuario y qué necesita saber o ver exactamente; luego podrás construir la interfaz que le ayude a interactuar y entender mejor esos datos.

Estos son datos que te proponemos:

3. Objetivos de aprendizaje

El objetivo principal de este proyecto es que, entendiendo las necesidades de tus usuarios, aprendas a diseñar y construir una interfaz web donde se pueda visualizar y manipular data.

Revisa la lista y reflexiona sobre los objetivos que conseguiste en el proyecto anterior. Piensa en eso al decidir tu estrategia de trabajo individual y de equipo.

UX

  • Diseñar la aplicación pensando y entendiendo al usuario.
  • Crear prototipos para obtener feedback e iterar.
  • Aplicar los principios de diseño visual (contraste, alineación, jerarquía).
  • Planear y ejecutar tests de usabilidad.

HTML y CSS

  • Entender y reconocer por qué es importante el HTML semántico.
  • Identificar y entender tipos de selectores en CSS.
  • Entender como funciona flexbox en CSS.
  • Construir tu aplicación respetando el diseño planeado (maquetación).

DOM

  • Entender y reconocer los selectores del DOM (querySelector | querySelectorAll).
  • Manejar eventos del DOM. (addEventListener)
  • Manipular dinámicamente el DOM. (createElement, appendchild, innerHTML, value)

Javascript

  • Manipular arrays (filter | map | sort | reduce).
  • Manipular objects (key | value).
  • Entender el uso de condicionales (if-else | switch).
  • Entender el uso de bucles (for | forEach).
  • Entender la diferencia entre expression y statements.
  • Utilizar funciones (parámetros | argumentos | valor de retorno).
  • Entender la diferencia entre tipos de datos atómicos y estructurados.
  • Utilizar ES Modules (import | export).

Pruebas Unitarias (testing)

  • Testear funciones (funciones puras).

Git y GitHub

  • Ejecutar comandos de git (add | commit | pull | status | push).
  • Utilizar los repositorios de GitHub (clone | fork | gh-pages).
  • Colaborar en Github (pull requests).

Buenas prácticas de desarrollo

  • Organizar y dividir el código en módulos (Modularización).
  • Utilizar identificadores descriptivos (Nomenclatura | Semántica).
  • Utilizar linter para seguir buenas prácticas (ESLINT).

4. Consideraciones generales

  • Este proyecto se debe resolver en duplas.
  • El proyecto será entregado subiendo tu código a GitHub (commit/push) y la interfaz será desplegada usando GitHub Pages.
  • Tiempo para completarlo: Toma como referencia 4 semanas.

5. Criterios de aceptación mínimos del proyecto

Los criterios para considerar que has completado este proyecto son:

Definición del producto

Documenta brevemente tu trabajo en el archivo README.md de tu repositorio, contándonos cómo fue tu proceso de diseño y cómo crees que el producto resuelve el problema (o problemas) que tiene tu usuario.

Historias de usuario

Una vez que entiendas las necesidades de tus usuarios, escribe las Historias de Usuario que representen todo lo que el usuario necesita hacer/ver. Las Historias de Usuario deben ser el resultado de tu proceso de investigación o research de tus usuarios.

Asegúrate de incluir la definición de terminado (definition of done) y los Criterios de Aceptación para cada una.

En la medida de lo posible, termina una historia de usuario antes de pasar a la siguiente (Cumple con Definición de Terminado + Criterios de Aceptación).

Diseño de la Interfaz de Usuario

Prototipo de baja fidelidad

Durante tu trabajo deberás haber hecho e iterado bocetos (sketches) de tu solución usando papel y lápiz. Te recomendamos tomar fotos de todas las iteraciones que hagas, que las subas a tu repositorio y las menciones en tu README.md.

Prototipo de alta fidelidad

Lo siguiente es diseñar tu Interfaz de Usuario (UI por sus siglas en inglés - User Interface). Para eso debes aprender a utilizar alguna herramienta de diseño visual. Nosotros te recomendamos Figma que es una herramienta que funciona en el navegador y, además, puedes crear una cuenta gratis. Sin embargo, eres libre de utilizar otros editores gráficos como Illustrator, Photoshop, PowerPoint, Keynote, etc. Recuerda utilizar la identidad gráfica correspondiente a cada set de datos que elijas.

El diseño debe representar el ideal de tu solución. Digamos que es lo que desearías implementar si tuvieras tiempo ilimitado para trabajar. Además, tu diseño debe seguir los fundamentos de visual design.

Testeos de usabilidad

Durante el reto deberás hacer tests de usabilidad con distintos usuarios, y en base a los resultados, deberás iterar tus diseños. Cuéntanos qué problemas de usabilidad detectaste a través de los tests y cómo los mejoraste en tu propuesta final.

Implementación de la Interfaz de Usuario (HTML/CSS/JS)

Luego de diseñar tu interfaz de usuario deberás trabajar en su implementación. No es necesario que construyas la interfaz exactamente como la diseñaste. No tienes tiempo ilimitado para trabajar, así es que deberás priorizar.

Como mínimo, tu implementación debe:

  1. Mostrar la data en una interfaz: puede ser un card, una tabla, una lista, etc.
  2. Permitir al usuario interactuar para obtener la infomación que necesita.
  3. Ser responsive, es decir, debe visualizarse sin problemas desde distintos tamaños de pantallas: móviles, tablets y desktops.
  4. Que la interfaz siga los fundamentos de visual design.

Pruebas unitarias

El boilerplate de este proyecto no incluye Pruebas Unitarias (tests), así es que tendrás que escribirlas tú para las funciones que tenga tu código.

Tus pruebas unitarias deben dar una cobertura del 70% de statements (sentencias), functions (funciones), lines (líneas), y branches (ramas) del archivo src/data.js que contenga tus funciones y está detallado en la sección de Consideraciones técnicas.

6. Hacker edition

Las secciones llamadas Hacker Edition son opcionales. Si terminaste con todo lo anterior y te queda tiempo, intenta completarlas. Así podrás profundizar y/o ejercitar más sobre los objetivos de aprendizaje del proyecto.

Features/características extra sugeridas:

  • En lugar de consumir la data estática brindada en este repositorio, puedes consumir la data de forma dinámica, cargando un archivo JSON por medio de fetch. La carpeta src/data contiene una versión .js y una .json de de cada set datos.
  • Agregarle a tu interfaz de usuario implementada visualizaciones gráficas. Para ello te recomendamos explorar librerías de gráficas como Chart.js o Google Charts.
  • 100% Coverage

7. Consideraciones técnicas

La lógica del proyecto debe estar implementada completamente en JavaScript (ES6), HTML y CSS. En este proyecto NO está permitido usar librerías o frameworks, solo vanilla JavaScript, con la excepción de librerías para hacer gráficas (charts); ver Parte opcional más arriba.

No se debe utilizar la pseudo-variable this.

El boilerplate contiene una estructura de archivos como punto de partida así como toda la configuración de dependencias:

.
├── EXTRA.md
├── README.md
├── package.json
├── src
|  ├── data (según con qué data trabajes)
|  |  ├── lol
|  |  |  ├── lol.js
|  |  |  ├── lol.json
|  |  |  └── README.md
|  |  ├── pokemon
|  |  |  ├── pokemon.js
|  |  |  ├── pokemon.json
|  |  |  └── README.md
|  |  └── atletas
|  |     ├── atletas.js
|  |     └── atletas.json
|  |     └── README.md
|  ├── data.js
|  ├── index.html
|  ├── main.js
|  └── style.css
└── test
   └── data.spec.js

directory: 6 file: 17

src/index.html

Como en el proyecto anterior, existe un archivo index.html. Como ya sabes, acá va la página que se mostrará al usuario. También nos sirve para indicar qué scripts se usarán y unir todo lo que hemos hecho.

src/main.js

Recomendamos usar src/main.js para todo tu código que tenga que ver con mostrar los datos en la pantalla. Con esto nos referimos básicamente a la interacción con el DOM. Operaciones como creación de nodos, registro de manejadores de eventos (event listeners o event handlers), ....

Esta no es la única forma de dividir tu código, puedes usar más archivos y carpetas, siempre y cuando la estructura sea clara para tus compañeras.

En este archivo encontrarás una serie de imports comentados. Para cargar las diferentes fuentes de datos tendrás que descomentar la línea correspondiente.

Por ejemplo, si "descomentamos" la siguiente línea:

// import data from './data/pokemon/pokemon.js';

La línea quedaría así:

import data from './data/pokemon/pokemon.js';

Y ahora tendríamos la variable data disponible en el script src/main.js.

src/data.js

El corazón de este proyecto es la manipulación de datos a través de arreglos y objetos.

Te reomendamos que este archivo contenga toda la funcionalidad que corresponda a obtener, procesar y manipular datos (tus funciones). Por ejemplo:

  • filterData(data, condition): esta función filter o filtrar recibiría la data, y nos retornaría aquellos datos que sí cumplan con la condición.

  • sortData(data, sortBy, sortOrder): esta función sort u ordenar recibe tres parámetros. El primer parámetro, data, nos entrega los datos. El segundo parámetro, sortBy, nos dice con respecto a cuál de los campos de la data se quiere ordenar. El tercer parámetro, sortOrder, indica si se quiere ordenar de manera ascendente o descendente.

  • computeStats(data): la función compute o calcular, nos permitirá hacer cálculos estadísticos básicos para ser mostrados de acuerdo a la data proporcionada.

Estos nombres de funciones y de parámetros son solamente referenciales, lo que decidas depende de tu propia implementación.

Estas funciones deben ser puras e independientes del DOM. Estas funciones serán después usadas desde el archivo src/main.js, al cargar la página, y cada vez que el usuario interactúe (click, filtrado, ordenado, ...).

src/data

En esta carpeta están los datos de las diferentes fuentes. Encontrarás una carpeta por cada fuente, y dentro de cada carpeta dos archivos: uno con la extensión .js y otro .json. Ambos archivos contienen la misma data; la diferencia es que el .js lo usaremos a través de una etiqueta <script>, mientras que el .json está ahí para opcionalmente cargar la data de forma asíncrona con fetch() (ver sección de Parte Opcional).

test/data.spec.js

Tendrás también que completar las pruebas unitarias de las funciones implementadas en el archivo data.js.

8. Pistas, tips y lecturas complementarias

Primeros pasos

Antes de empezar a escribir código, debes definir qué deberá hacer el producto en base al conocimiento que puedas obtener de tu usuario. Estas preguntas te pueden ayudar:

  • ¿Quiénes son los principales usuarios de producto?
  • ¿Cuáles son los objetivos de estos usuarios en relación con el producto?
  • ¿Cuáles son los datos más relevantes que quieren ver en la interfaz y por qué?
  • ¿Cuándo utilizan o utilizarían el producto?
  • Toda tu investigación previa debe tener como resultado todas las Historias de Usuario de tu proyecto.
  • No hagas los prototipos de alta fidelidad de todas tus Historias. Comienza solamente por los que se necesiten para tu Sprint 1 (semana 1 de trabajo). Más pistas en la guía de organización para el proyecto.

Cuando ya estés lista para codear, te sugerimos empezar de esta manera:

  1. Una de las integrantes del equipo debe realizar un 🍴 fork del repo de tu cohort, tus coaches te compartirán un link a un repo y te darán acceso de lectura en ese repo. La otra integrante del equipo deber hacer un fork del repositorio de su compañera y configurar un remote hacia el mismo.
  2. ⬇️ Clona tu fork a tu computadora (copia local).
  3. 📦 Instala las dependencias del proyecto con el comando npm install. Esto asume que has instalado Node.js (que incluye npm).
  4. Si todo ha ido bien, deberías poder ejecutar las 🚥 pruebas unitarias (unit tests) con el comando npm test.
  5. Para ver la interfaz de tu programa en el navegador, usa el comando npm start para arrancar el servidor web y dirígete a http://localhost:5000 en tu navegador.
  6. A codear se ha dicho! 🚀

Contenido de referencia

Diseño de experiencia de usuario (User Experience Design)

  • Investigación con usuarios / entrevistas
  • Principios de diseño visual

Desarrollo Front-end

Herramientas

Organización del Trabajo


9. Checklist

  • Usa VanillaJS.
  • No hace uso de this.
  • Pasa linter (npm run pretest)
  • Pasa tests (npm test)
  • Pruebas unitarias cubren un mínimo del 70% de statements, functions y lines y branches.
  • Incluye Definición del producto clara e informativa en README.md.
  • Incluye historias de usuario en README.md.
  • Incluye sketch de la solución (prototipo de baja fidelidad) en README.md.
  • Incluye Diseño de la Interfaz de Usuario (prototipo de alta fidelidad) en README.md.
  • Incluye link a Zeplin en README.md.
  • Incluye el listado de problemas que detectaste a través de tests de usabilidad en el README.md.
  • UI: Muestra lista y/o tabla con datos y/o indicadores.
  • UI: Permite ordenar data por uno o más campos (asc y desc).
  • UI: Permite filtrar data en base a una condición.
  • UI: Es responsive.