Files
roi-theme/Shared/Application/UseCases/EvaluateComponentVisibility/EvaluateComponentVisibilityUseCase.php
FrankZamora 0c1908e7d1 chore(php): add toc debug logging for guest visibility issue
Temporary debug logging to diagnose why TOC shows for logged users
but not for guests. Logs visibility checks at each layer.

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

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-06 23:03:42 -06:00

64 lines
2.0 KiB
PHP

<?php
declare(strict_types=1);
namespace ROITheme\Shared\Application\UseCases\EvaluateComponentVisibility;
use ROITheme\Shared\Application\UseCases\EvaluatePageVisibility\EvaluatePageVisibilityUseCase;
use ROITheme\Shared\Application\UseCases\EvaluateExclusions\EvaluateExclusionsUseCase;
/**
* Caso de uso: Evaluar visibilidad completa de un componente
*
* Orquesta la evaluacion de:
* 1. Visibilidad por tipo de pagina (Plan 99.10)
* 2. Reglas de exclusion (Plan 99.11)
*
* El componente se muestra SOLO si:
* - Pasa la verificacion de tipo de pagina
* - NO esta excluido por ninguna regla
*
* PATRON: Facade/Orchestrator - combina dos UseCases
*
* @package ROITheme\Shared\Application\UseCases\EvaluateComponentVisibility
*/
final class EvaluateComponentVisibilityUseCase
{
public function __construct(
private readonly EvaluatePageVisibilityUseCase $pageVisibilityUseCase,
private readonly EvaluateExclusionsUseCase $exclusionsUseCase
) {}
/**
* Evalua si el componente debe mostrarse en la pagina actual
*
* @param string $componentName Nombre del componente (kebab-case)
* @return bool True si debe mostrarse
*/
public function execute(string $componentName): bool
{
// DEBUG: Log for TOC only
$debugToc = ($componentName === 'table-of-contents');
// Paso 1: Verificar visibilidad por tipo de pagina
$visibleByPageType = $this->pageVisibilityUseCase->execute($componentName);
if ($debugToc) {
error_log("EvaluateComponentVisibility [{$componentName}]: visibleByPageType=" . ($visibleByPageType ? "true" : "false"));
}
if (!$visibleByPageType) {
return false;
}
// Paso 2: Verificar exclusiones
$isExcluded = $this->exclusionsUseCase->execute($componentName);
if ($debugToc) {
error_log("EvaluateComponentVisibility [{$componentName}]: isExcluded=" . ($isExcluded ? "true" : "false"));
}
// Mostrar si NO esta excluido
return !$isExcluded;
}
}