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>
This commit is contained in:
FrankZamora
2025-11-25 21:20:06 -06:00
parent 90de6df77c
commit 0846a3bf03
224 changed files with 21670 additions and 17816 deletions

View File

@@ -0,0 +1,121 @@
<?php
declare(strict_types=1);
namespace ROITheme\Shared\Application\UseCases\SaveComponent;
/**
* SaveComponentResponse - DTO de salida para guardar componente
*
* RESPONSABILIDAD: Encapsular el resultado del Use Case (<28>xito o fallo)
*
* PATR<54>N: Success/Failure
* - <20>xito: success=true, data contiene el componente guardado
* - Fallo: success=false, errors contiene array de errores
*
* CARACTER<45>STICAS:
* - Inmutable
* - Constructor privado (usar factory methods)
* - Factory methods: success() y failure()
*
* USO:
* ```php
* // <20>xito
* $response = SaveComponentResponse::success(['name' => 'top_bar', ...]);
* if ($response->isSuccess()) {
* $data = $response->getData();
* }
*
* // Fallo
* $response = SaveComponentResponse::failure(['Error de validaci<63>n']);
* if (!$response->isSuccess()) {
* $errors = $response->getErrors();
* }
* ```
*
* @package ROITheme\Shared\Application\UseCases\SaveComponent
*/
final readonly class SaveComponentResponse
{
/**
* Constructor privado - usar factory methods
*
* @param bool $success Indica si la operaci<63>n fue exitosa
* @param mixed $data Datos del componente guardado (solo si success=true)
* @param array|null $errors Array de errores (solo si success=false)
*/
private function __construct(
private bool $success,
private mixed $data,
private ?array $errors
) {}
/**
* Verificar si la operaci<63>n fue exitosa
*
* @return bool
*/
public function isSuccess(): bool
{
return $this->success;
}
/**
* Obtener datos del componente guardado
*
* Solo v<>lido si isSuccess() === true
*
* @return mixed
*/
public function getData(): mixed
{
return $this->data;
}
/**
* Obtener errores
*
* Solo v<>lido si isSuccess() === false
*
* @return array|null
*/
public function getErrors(): ?array
{
return $this->errors;
}
/**
* Factory method: Crear respuesta exitosa
*
* @param mixed $data Datos del componente guardado
* @return self
*/
public static function success(mixed $data): self
{
return new self(true, $data, null);
}
/**
* Factory method: Crear respuesta de fallo
*
* @param array $errors Array de mensajes de error
* @return self
*/
public static function failure(array $errors): self
{
return new self(false, null, $errors);
}
/**
* Convertir a array para serializaci<63>n (JSON, etc.)
*
* @return array
*/
public function toArray(): array
{
return [
'success' => $this->success,
'data' => $this->data,
'errors' => $this->errors
];
}
}