Files
roi-theme/shared/Application/UseCases/GetComponentSettings/GetComponentSettingsUseCase.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

47 lines
1.2 KiB
PHP

<?php
declare(strict_types=1);
namespace ROITheme\Shared\Application\UseCases\GetComponentSettings;
use ROITheme\Shared\Domain\Contracts\ComponentSettingsRepositoryInterface;
/**
* Caso de uso para obtener las configuraciones de un componente
*
* Application Layer - Orquesta la lógica de negocio
*
* @package ROITheme\Shared\Application\UseCases\GetComponentSettings
*/
final class GetComponentSettingsUseCase
{
public function __construct(
private ComponentSettingsRepositoryInterface $repository
) {
}
/**
* Ejecuta el caso de uso
*
* @param string $componentName Nombre del componente
* @return array<string, array<string, mixed>> Configuraciones agrupadas por grupo
*/
public function execute(string $componentName): array
{
// Validar entrada
if (empty($componentName)) {
return [];
}
// Obtener configuraciones del repositorio
$settings = $this->repository->getComponentSettings($componentName);
// Si no hay configuraciones, devolver array vacío
if (empty($settings)) {
return [];
}
return $settings;
}
}