01_Init_description
The Secret of Princess nació como un proyecto personal, de esos que no empiezan con una gran planificación técnica, sino con una necesidad real y bastante humana: mantener viva la motivación dentro de una relación a distancia.
Mi novia y yo tenemos una relación a distancia, y como en cualquier historia donde los kilómetros se meten en medio, buscamos pequeñas formas de sentirnos más cerca. Esta app es una de ellas.
La idea es simple: crear pequeñas tareas, retos o logros que podamos cumplir, y asociarlos a una recompensa. No se trata solo de “hacer cosas”, sino de convertir detalles cotidianos en momentos compartidos. Una manera de alentarnos, cuidarnos y mantener una dinámica divertida incluso cuando no estamos físicamente juntos.
Más que una aplicación pensada para escalar o convertirse en producto, este proyecto es un espacio privado, emocional y técnico a la vez. Un pequeño sistema hecho por hobby, pero con mucho significado detrás.
Porque a veces programar también es una forma de decir: “estoy aquí, aunque esté lejos”.
Bajo el Capó




Aunque The Secret of Princess nació como un proyecto personal y bastante emocional, también fue una buena excusa para seguir experimentando con un stack moderno, ligero y fácil de mantener.
La aplicación está construida con tecnologías pensadas para moverse rápido, desplegar sin fricción y mantener el proyecto vivo sin convertirlo en una carga de mantenimiento.
Stack principal
- Vite — Herramienta principal para construir y servir el frontend de forma rápida.
- React — Librería utilizada para crear la interfaz y los componentes interactivos de la aplicación.
- InsForge — Backend del proyecto, utilizado para gestionar la lógica y los servicios necesarios de la app.
- Docker — Contenerización de la aplicación para ejecutarla de forma consistente en el servidor.
- GitHub Actions — Automatización del deploy; la aplicación se actualiza sola en el servidor después de cada commit.
- Git & GitHub — Control de versiones y gestión del repositorio del proyecto.

Discussion