- 1. TRIPTIME ... Comparte experiencias auténticas de viaje
- 2. Resumen del proyecto
- 3. Objetivos de aprendizaje
- 4. Consideraciones generales para Red Social TRIPTIME
- 5. Criterios de aceptación mínimos del proyecto
- 6. Entrega
Las redes sociales han invadido nuestras vidas, decidimos realizar una red social para viajeros donde se pueda intercambiar consejos, leer reseñas de hoteles, buscar compañero de viaje, dar like a publicaciones de otros viajeros... Las redes sociales están revolucionando nuestra forma de viajar. Si bien redes sociales más populares como Facebook o Twitter tienen buen predicamento entre muchos trotamundos, no deja de crecer el número de redes sociales de viajeros más especializadas. ¡Echa un vistazo a nuestra app TRIPTIME!
Nuestra Red Social permite a cualquier usuario crear una cuenta de acceso, loguearse con ella y acceso con una cuenta Google; creaa, edita, borra y "likear" publicacciones.
El objetivo principal de aprendizaje de este proyecto es construir una Single-page Application (SPA) & Es responsive para versión mobile en la que se puede leer y escribir datos.
Los Objetivos de aprendizaje alcanzados:
- [✓] Uso de HTML semántico
- [✓] Uso de selectores de CSS
- [✓] Modelo de caja (box model): borde, margen, padding
- [✓] Uso de flexbox en CSS
- [✓] Uso de CSS Grid Layout
-
[✓] Uso de selectores del DOM
-
[✓] Manejo de eventos del DOM (listeners, propagación, delegación)
-
[✓] Manipulación dinámica del DOM
- Node.appendChild()
- Document.createElement()
- Document.createTextNode()
- Element.innerHTML
- Node.textContent
-
[✓] Ruteado (History API, evento hashchange, window.location)
- Manipulando el historial del navegador
- [✓] Arrays (arreglos)
- [✓] Objetos (key, value)
- [✓] Diferenciar entre tipos de datos primitivos y no primitivos
- [✓] Variables (declaración, asignación, ámbito)
- [✓] Uso de condicionales (if-else, switch, operador ternario, lógica booleana)
- [✓] Uso de bucles/ciclos (while, for, for..of)
- [✓] Funciones (params, args, return)
- Pruebas unitarias (unit tests)
- [✓] Pruebas asíncronas
- Uso de mocks y espías
- [✓] Módulos de ECMAScript (ES Modules)
- [✓] Uso de linter (ESLINT)
- [✓] Uso de identificadores descriptivos (Nomenclatura y Semántica)
- [✓] Diferenciar entre expresiones (expressions) y sentencias (statements)
- [✓] Callbacks
- [✓] Promesas
- [✓] Git: Instalación y configuración
- [✓] Git: Control de versiones con git (init, clone, add, commit, status, push, pull, remote)
- [✓] Git: Integración de cambios entre ramas (branch, checkout, fetch, merge)
- [✓] GitHub: Creación de cuenta y repos, configuración de llaves SSH
- [✓] GitHub: Despliegue con GitHub Pages
- [✓] GitHub: Colaboración en Github (branches | forks | pull requests | tags)
- [✓] Diseñar un producto o servicio poniendo a la usuaria en el centro
- [✓] Crear prototipos de alta fidelidad que incluyan interacciones
- [✓] Seguir los principios básicos de diseño visual
- [✓] Planear y ejecutar testeos de usabilidad de prototipos en distintos niveles de fidelidad
- [✓] Firebase Auth
- [✓] Firestore
- Este proyecto se trabajo en triada.
- La lógica del proyecto esta implementada completamente en JavaScript (ES6+), HTML y CSS.
- Se trabajo con historias de usurio. La historia se completa cuando se cumplen todos sus Criterios de Aceptación + toda su Definición de Terminado.
- ¿Quiénes son los principales usuarios de producto? La red social TRIPTIME es utilizada por los amantes a los viajes.
- ¿Qué problema resuelve el producto / para qué le servirá a estos usuarios.? En esta app se pueda intercambiar consejos, leer reseñas de hoteles, buscar compañero de viaje, dar like a publicaciones de otros viajeros... Las redes sociales están revolucionando nuestra forma de viajar.
Realizamos la planeación del proyecto en Trello Trello
Los criterios que consideramos para desarrollar este proyecto son: HU1 Yo como usuario quiero registrar una cuenta de acceso con mi correo electronico y contraseña para acceder a la red social de viajeros HU2 Yo como usuario quiero iniciar sesión con una cuenta existente de correo electronico para acceder a la red social de viajeros HU3 Crear un post HU4 Likear un post (Dan) HU5 Eliminar un post (Nan) HU6 Editar un post (Abril) HU7 Contar los likes de una publicación
-
Criterios de Aceptación: todo lo que debe ocurrir para satisfacer las necesidades del usuario.
-
Definición de terminado: todos los aspectos técnicos que se cumplieron para que, como equipo, supimos que esa historia está terminada y lista para publicarse. Todas las Historias de Usuario (salvo excepciones), deben incluir estos aspectos en su Definición de Terminado (más todo lo que necesito agregar):
Tomamos foto de los diseños que prentendimos realizar a papel y lápiz.
Se definio cuál fue el flujo que seguirá el usuario dentro de la aplicación y se diseño la Interfaz de Usuario, el prototipo se realiza en Figma Figma
Se puede ver en mobile first
.
Estas consideraciones te ayudarán a escribir las Definiciones de Terminado de tus H.U.:
-
Login con Firebase:
- Para el login se utilizo Firebase
- Creación de cuenta de acceso y autenticación con cuenta de correo y contraseña, y también con una cuenta de Google.
-
Validaciones:
-
Comportamiento:
- Validaciones:
- Al publicar se utilizo Firestore, se debe validar que exista contenido en el input.
- Comportamiento:
- Al recargar la aplicación, se debe verificar si el usuario está logueado antes de mostrar contenido.
- Poder publicar un post.
- Poder dar y quitar like a una publicación. Máximo uno por usuario.
- Llevar un conteo de los likes.
- Poder eliminar un post específico.
- Pedir confirmación antes de eliminar un post.
- Al dar click para editar un post, debe cambiar el texto por un input que permita editar el texto y luego guardar los cambios.
- Al guardar los cambios debe cambiar de vuelta a un texto normal pero con la información editada.
- Al recargar la página debo de poder ver los textos editados.
Se realizó GitHub Colaborativo donde 3 autores (Abril Quintero, Daniela Carbajal & Nanci Mondragón).
Enviaron 3 confirmaciones a la principal y 3 confirmaciones a todas las ramas. En main, 15 archivos
han cambiado y ha habido 178 adiciones y 66 eliminaciones .