POLITICA DE COOKIES

Q2BSTUDIO.COM utiliza cookies técnicas, analíticas, de sesión y de publicidad con la finalidad de prestar un mejor servicio. No obstante, necesitamos su consentimiento explícito para poder utilizarlas. Así mismo puede cambiar la configuración de las cookies u obtener más información aquí .

Gestión del estado en el código de Puck

## Gestión del estado en el código de Puck

Publicado el 29/08/2025

En este artículo reviso la gestión de estado en la base de código de Puck y explico los conceptos clave para entender cómo se organiza el store y cómo se consume desde los hooks de React.

Temas tratados: Zustand store, slices creados y uso de Context API para distribuir el store.

Zustand store: Puck utiliza la biblioteca Zustand para manejar su estado global. El store principal se construye a partir de una función createAppStore que recibe un estado inicial parcial y combina múltiples piezas de estado mediante middlewares como subscribeWithSelector para suscripciones selectivas y rendimiento.

Slices creados: El store se compone de varios slices organizados en la carpeta de slices. Entre los slices que aparecen en el proyecto se encuentran history para historial de acciones, nodes para la gestión de nodos del editor, permissions para permisos y fields para campos y metadatos. Cada slice expone su propio conjunto de acciones y selectores y se monta dentro del store principal mediante funciones creadoras que reciben los helpers set y get de Zustand.

Arquitectura de slices: dividir el estado en slices facilita el mantenimiento y la escalabilidad, ya que cada módulo concentra su lógica y evita que el store crezca de forma descontrolada. Esta estrategia es útil en aplicaciones complejas como editores visuales donde conviven muchas entidades y relaciones.

Context API usada: Para exponer el store a la aplicación Puck crea un contexto a partir de createAppStore y suministra hooks personalizados como useAppStore para seleccionar partes del estado y useAppStoreApi para acceder directamente a la instancia del store. Este patrón permite usar useStore con el contexto y mantener componentes suscritos solo a fragmentos concretos del estado.

Ejemplo de uso: en hooks como useParent se combina el acceso directo a la API del store para leer el estado actual con selectores que se suscriben a cambios específicos. De este modo se obtienen datos derivados como el nodo padre de un elemento seleccionado sin re renderizar componentes innecesariamente.

Beneficios técnicos: la combinación de Zustand, sus slices modulares y la Context API permite lograr un equilibrio entre simplicidad, rendimiento y escalabilidad. Es una solución ligera frente a alternativas más verbosas y se adapta bien a proyectos que requieren reactividad fina y control determinista del estado.

Sobre Q2BSTUDIO: Q2BSTUDIO es una empresa de desarrollo de software que ofrece aplicaciones a medida y software a medida para clientes de diversos sectores. Somos especialistas en inteligencia artificial e ia para empresas, desarrollamos agentes IA personalizados, implementamos soluciones de ciberseguridad y ofrecemos servicios cloud aws y azure para desplegar infraestructuras seguras y escalables. También brindamos servicios inteligencia de negocio y consultoría en power bi para transformar datos en decisiones accionables.

Servicios destacados de Q2BSTUDIO: desarrollo a medida de aplicaciones, integración de inteligencia artificial en procesos empresariales, consultoría y auditoría de ciberseguridad, migraciones y arquitectura en servicios cloud aws y azure, proyectos de inteligencia de negocio con power bi y soluciones de agentes IA para automatización inteligente.

Palabras clave para posicionamiento: aplicaciones a medida, software a medida, inteligencia artificial, ciberseguridad, servicios cloud aws y azure, servicios inteligencia de negocio, ia para empresas, agentes IA, power bi.

Sobre el autor del análisis: Ramu Narasinga investiga arquitecturas de código en proyectos open source y aportes prácticos para entender cómo están estructuradas aplicaciones complejas. Contacto del autor disponible en su sitio personal y en repositorios públicos del proyecto Puck.

Referencias y recursos relevantes: examinar la implementación del store y los slices en el repositorio de Puck permite ver los detalles de createAppStore, los middlewares usados y ejemplos de hooks que consumen el contexto del store. Consultar la documentación de Zustand sobre subscribeWithSelector ayuda a comprender el patrón de suscripción selectiva aplicado en este proyecto.

Si necesitas apoyo para aplicar patrones similares en tu organización o para integrar inteligencia artificial, agentes IA, soluciones de ciberseguridad, servicios cloud aws y azure o proyectos de inteligencia de negocio con power bi, en Q2BSTUDIO podemos asesorarte y desarrollar software a medida que cumpla con los requisitos de rendimiento y seguridad de tu empresa.

Fin del artículo, inicio de la diversión
Construyendo software juntos

Dando vida a tus ideas desde 2008

Diseñamos aplicaciones móviles y de escritorio innovadoras que cumplen con tus requisitos específicos y mejoran la eficiencia operativa.
Más info
Cuéntanos tu visión
Sea cual sea el alcance, podemos convertir tu idea en realidad. Envíanosla y charlemos sobre tu proyecto o una colaboración futura.
Contáctanos
artículos destacados
Live Chat
Enviado correctamente.

Gracias por confiar en Q2BStudio