Files
roi-theme/Public/CustomCSSManager/Application/UseCases/GetDeferredSnippetsUseCase.php
FrankZamora 9cb0dd1491 feat(custom-css-manager): implementar TIPO 3 - CSS Crítico Personalizado
Nuevo sistema de gestión de CSS personalizado con panel admin:
- Admin/CustomCSSManager: CRUD de snippets CSS (crítico/diferido)
- Public/CustomCSSManager: Inyección dinámica en frontend
- Schema JSON para configuración del componente

Migración de CSS estático a BD:
- Tablas APU (~14KB) → snippet diferido en BD
- Tablas Genéricas (~10KB) → snippet diferido en BD
- Comentadas funciones legacy en enqueue-scripts.php

Limpieza de archivos obsoletos:
- Eliminado build-bootstrap-subset.js
- Eliminado migrate-legacy-options.php
- Eliminado minify-css.php
- Eliminado purgecss.config.js

Beneficios:
- CSS editable desde admin sin tocar código
- Soporte crítico (head) y diferido (footer)
- Filtrado por scope (all/home/single/archive)

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-01 15:43:25 -06:00

31 lines
863 B
PHP

<?php
declare(strict_types=1);
namespace ROITheme\Public\CustomCSSManager\Application\UseCases;
use ROITheme\Shared\Domain\Contracts\CSSSnippetRepositoryInterface;
/**
* Caso de uso: Obtener snippets diferidos para página actual
*
* Contexto: Public (renderizado)
* Se ejecuta en wp_footer para cargar CSS no crítico.
*/
final class GetDeferredSnippetsUseCase
{
public function __construct(
private readonly CSSSnippetRepositoryInterface $repository
) {}
/**
* Ejecuta la obtención de snippets diferidos
*
* @param string $pageType Tipo de página actual ('home', 'posts', 'pages', 'archives', 'all')
* @return array<array> Snippets diferidos aplicables a la página
*/
public function execute(string $pageType): array
{
return $this->repository->getForPage('deferred', $pageType);
}
}