Files
roi-theme/shared/Domain/Contracts/RendererInterface.php
FrankZamora 0846a3bf03 Migración completa a Clean Architecture con componentes funcionales
- Reorganización de estructura: Admin/, Public/, Shared/, Schemas/
- 12 componentes migrados: TopNotificationBar, Navbar, CtaLetsTalk, Hero,
  FeaturedImage, TableOfContents, CtaBoxSidebar, SocialShare, CtaPost,
  RelatedPost, ContactForm, Footer
- Panel de administración con tabs Bootstrap 5 funcionales
- Schemas JSON para configuración de componentes
- Renderers dinámicos con CSSGeneratorService (cero CSS hardcodeado)
- FormBuilders para UI admin con Design System consistente
- Fix: Bootstrap JS cargado en header para tabs funcionales
- Fix: buildTextInput maneja valores mixed (bool/string)
- Eliminación de estructura legacy (src/, admin/, assets/css/componente-*)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-25 21:20:06 -06:00

56 lines
1.5 KiB
PHP

<?php
declare(strict_types=1);
namespace ROITheme\Shared\Domain\Contracts;
use ROITheme\Shared\Domain\Entities\Component;
/**
* RendererInterface - Contrato para renderizadores de componentes
*
* RESPONSABILIDAD: Definir el contrato que deben cumplir todos los renderizadores
* de componentes para generar HTML a partir de los datos del componente.
*
* PRINCIPIOS:
* - Interface Segregation: Una sola responsabilidad - renderizar HTML
* - Dependency Inversion: Depender de abstracción, no de implementación
*
* USO:
* ```php
* final class MyRenderer implements RendererInterface
* {
* public function render(Component $component): string
* {
* $data = $component->getData();
* // Generar HTML
* return $html;
* }
*
* public function supports(string $componentType): bool
* {
* return $componentType === 'my-component';
* }
* }
* ```
*
* @package ROITheme\Domain\Component
*/
interface RendererInterface
{
/**
* Renderizar un componente a HTML
*
* @param Component $component Componente a renderizar
* @return string HTML generado
*/
public function render(Component $component): string;
/**
* Verificar si este renderizador soporta un tipo de componente
*
* @param string $componentType Tipo de componente (ej: 'navbar', 'footer')
* @return bool True si soporta el tipo, false en caso contrario
*/
public function supports(string $componentType): bool;
}