Regalos, Regalar, Regalame

Un poco sobre lo aprendido y la historia de regalame.app 🎁

Recibir un pequeño o gran regalo es el nexo que nos hace sentir cerca de las personas que queremos. — https://regalame.app/

Regalame te permite crear listas de regalos para compartir con otras personas, usando tus favoritos de Mercado Libre.

La idea surgió de @co_constanza cuando comentó su deseo de compartir con otras personas su lista de favoritos de Mercado Libre, para que le manden y poder mandar regalitos.

La idea tomó vuelo y consultando con otras personas fue evidente que compartían el mismo deseo. Además, en Twitter había muchas personas que también lo estaban pidiendo.

Bien, entonces ¿por qué no crear algo y aprender en el intento?

Si hay algo que me gusta es em-aprender sobre un proyecto que “cobre vida” y esta iba a ser una linda oportunidad.

Lo primero que me pregunté fue: ¿Qué cosas quiero aprender / probar? (spoiler sobre que sí y que no llegué).

  • Serverless en general ✓
  • Rust ❌
  • Una base de datos NoSQL ✓
  • Usar Next.js en un proyecto real con: ✓
  • Server Side Rendering ✓
  • SWR ❌
  • ISR ✓
  • Cloudflare Workers ❌
  • React Hooks ✓
  • CSS Grids y Flexbox ✓
  • Usar el VoiceOver para accesibilidad ✓

El stack que usé es gratuito por defecto y si bien tiene sus limitaciones (puede que explote todo) es excelente para empezar:

Algunos puntos que me gustaría destacar de lo aprendido…

Siendo un gran amante de la web performance, tenía muchas ganas de jugar con Incremental Static Regeneration (ISR).

Considero que es un feature que marca un antes-y-después para el frontend y para servir el contenido lo más rápido posible.

When a request is made to a page that hasn’t been generated, Next.js will server-render the page on the first request. Future requests will serve the static file from the cache.

Los perfiles de regalame pueden cambiar sumando o eliminando listas o regalos. Por eso, la mejor forma para manejar su dinamismo es usando la opción fallback: blocking.

De esta manera, los perfiles y listas se generan a demanda la primera vez que se piden y luego quedan cacheadas en el edge y en el navegador, revalidándose cada 1 segundo.

Primer request al perfil, generado a demanda

Subsiguientes requests al perfil, cacheado en el edge

Subsiguientes requests al perfil, cacheado en el navegador

Mientras iba construyendo las vistas me cuestionaba cuál era la información relevante para quién estaba navegando.

Es así como fui pensando y probando con el VoiceOver cómo iba quedando la experiencia al navegar con un lector de pantalla.

Luego de varias iteraciones, llegué a la conclusión que lo importante es poder leer el título y preció de lo que se quiere regalar. Es por eso que le indico al lector que no lea las imágenes de los productos en general y queda una experiencia mucho más limpia (quedo antento al feedback sobre este punto, ya que no estoy seguro).

https://twitter.com/pazguille/status/1381031963180556290

Esta iniciativa se empezó a desarrollar junto a otras personas a mediados del 2020 pero el contexto de pandemia sumado a cuestiones personales hizo que se frenara y continuara de forma independiente.

Recién en Marzo de 2021, retomé el desarrollo y quiero darle las gracias a Maria Lía Sediari quién me motivó y acompañó con ideas y contenidos.

@impronunciable y @joniko quienes me acompañan siempre desde lo profesional y personal, tirando magia, diseño y aguantando los trapos.

@lucianov quien se copó y me reportó muchos bugs desde sus listas de regalos ¡carísimos!

Meow. 🐈

Originally published at https://blog.pazguille.me.

👨‍💻 Front End Web Developer ⚡️ Web Performance Lover | Sr. Technical Manager at $MELI

👨‍💻 Front End Web Developer ⚡️ Web Performance Lover | Sr. Technical Manager at $MELI