ContentBuilderModal
Modal a pantalla completa que provee un layout de dos paneles: un ItemSelector lateral (en escritorio) o un Drawer (en móvil) a la izquierda, y un canvas de contenido a la derecha. Actualmente es un shell estructural — el área del canvas es un placeholder. Úsalo como base para integrar un editor de contenido basado en bloques o drag-and-drop.
Props
| Prop | Tipo | Requerido | Por defecto | Descripción |
|------|------|-----------|-------------|-------------|
| isOpen | boolean | Sí | — | Controla si el modal está visible. |
| onClose | () => void | Sí | — | Se llama cuando el modal se cierra. |
| title | string | Sí | — | Título mostrado en el encabezado del modal. |
| subtitle | string | No | — | Subtítulo mostrado debajo del título en el encabezado. |
| data | any[] \| null | No | — | Datos de contenido iniciales (reservado para uso futuro). |
| backdropStyle | React.CSSProperties | No | — | Estilos en línea para el backdrop del modal. |
| windowStyle | React.CSSProperties | No | — | Estilos en línea fusionados en la ventana del modal. |
| closeButtonStyle | React.CSSProperties | No | — | Estilos para el botón de cierre. |
| closeIcon | string | No | — | Nombre del ícono del botón de cierre. |
| closeIconPaths | any[] | No | — | Rutas de ícono personalizadas para el botón de cierre. |
| closeIconSize | number | No | — | Tamaño del ícono del botón de cierre. |
| zIndex | number | No | 99999 | z-index CSS del overlay del modal. |
| id | string | No | — | id HTML del elemento modal. |
| fullScreen | boolean | No | — | Cuando es true, el modal ocupa toda la pantalla. |
Uso
Básico
import React from 'react';
import ContentBuilderModal from '@/components/modals/ContentBuilderModal';
export default function Example() {
const [open, setOpen] = React.useState(false);
return (
<>
<button onClick={() => setOpen(true)}>Build Content</button>
<ContentBuilderModal
isOpen={open}
onClose={() => setOpen(false)}
title="Page Content Builder"
subtitle="Drag items to compose your page"
/>
</>
);
}