Implementación masiva de funcionalidades esenciales del tema apus-theme usando agentes paralelos para máxima eficiencia. **Issues Completados:** **Issue #2 - Eliminar bloat de WordPress:** - inc/performance.php: 13 funciones que remueven emojis, oEmbed, feeds, dashicons, jQuery migrate, XML-RPC, etc. - Optimización completa del frontend **Issue #3 - Desactivar búsqueda nativa:** - inc/search-disable.php: Bloquea queries de búsqueda, widget, formularios - search.php: Retorna 404 con mensaje amigable **Issue #4 - Desactivar comentarios:** - inc/comments-disable.php: 15 funciones que eliminan comentarios de frontend y backend - comments.php: Template desactivado **Issue #8 - Footer con 4 widgets:** - footer.php: Verificado con 4 áreas de widgets y copyright - assets/css/footer.css: Estilos responsive completos - Sistema de anchos configurables **Issue #9 - Jerarquía de plantillas:** - home.php, category.php, tag.php, author.php, date.php, taxonomy.php, attachment.php - 7 nuevas plantillas + 12 verificadas - Template parts completos - Paginación en todos los archives **Issue #10 - Imágenes destacadas:** - inc/featured-image.php: 12 funciones para manejo de featured images - Sin placeholders, lazy loading, alt text automático - Responsive con Bootstrap, aspect ratio **Issue #11 - Badge de categoría:** - inc/category-badge.php: Badge Bootstrap sobre H1 en single posts - Excluye "Uncategorized" - Template tag: apus_display_category_badge() **Issue #12 - TOC automático:** - inc/toc.php: Genera TOC desde H2/H3 - assets/css/toc.css: Estilos con numeración CSS counters - assets/js/toc.js: Smooth scroll, scroll spy, toggle - Configurable con apus_get_option() **Issue #13 - Posts relacionados:** - inc/related-posts.php: Query por categoría, 12 funciones - inc/admin/related-posts-options.php: Sistema de configuración - assets/css/related-posts.css: Cards responsive - Hook automático en single posts **Issue #16 - AdSense delay:** - inc/adsense-delay.php: Retardo de carga hasta scroll/click - assets/js/adsense-loader.js: Detecta interacciones - Mejora FID y TBT para Core Web Vitals **Archivos Modificados:** - functions.php: Includes de nuevos módulos, removido feed support - single.php: Integración de category badge - inc/enqueue-scripts.php: Enqueue de nuevos assets - inc/theme-options-helpers.php: Helper functions para TOC **Archivos Creados:** - 7 nuevas plantillas WordPress - 3 nuevos módulos inc/ (comments-disable, search-disable) - 8 reportes de documentación .md **Estadísticas:** - Total funciones PHP: 60+ nuevas funciones - Líneas de código: 2,500+ líneas - Archivos nuevos: 18 - Archivos modificados: 9 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
151 lines
5.2 KiB
PHP
151 lines
5.2 KiB
PHP
<?php
|
|
/**
|
|
* AdSense Delay Loading Functionality
|
|
*
|
|
* Delays the loading of AdSense scripts until user interaction or timeout
|
|
* to improve initial page load performance.
|
|
*
|
|
* @package Apus_Theme
|
|
* @since 1.0.0
|
|
*/
|
|
|
|
// Exit if accessed directly
|
|
if (!defined('ABSPATH')) {
|
|
exit;
|
|
}
|
|
|
|
/**
|
|
* Retarda la carga de scripts de AdSense interceptando el buffer de salida
|
|
*
|
|
* Esta función inicia el output buffering y reemplaza los scripts de AdSense
|
|
* con versiones retrasadas cuando se renderiza la página.
|
|
*/
|
|
function apus_delay_adsense_scripts() {
|
|
// Solo ejecutar en frontend
|
|
if (is_admin()) {
|
|
return;
|
|
}
|
|
|
|
// Verificar si el retardo de AdSense está habilitado en las opciones del tema
|
|
$delay_enabled = apus_get_option('apus_adsense_delay_enabled', '1');
|
|
|
|
if ($delay_enabled !== '1') {
|
|
return;
|
|
}
|
|
|
|
// Iniciar output buffering
|
|
ob_start('apus_replace_adsense_scripts');
|
|
}
|
|
add_action('template_redirect', 'apus_delay_adsense_scripts', 1);
|
|
|
|
/**
|
|
* Reemplaza scripts de AdSense con versiones retrasadas
|
|
*
|
|
* Esta función procesa la salida HTML y reemplaza las etiquetas de script
|
|
* estándar de AdSense con versiones de carga retrasada.
|
|
*
|
|
* @param string $html El contenido HTML a procesar
|
|
* @return string HTML modificado con scripts de AdSense retrasados
|
|
*/
|
|
function apus_replace_adsense_scripts($html) {
|
|
// Solo procesar si hay contenido real de AdSense
|
|
if (strpos($html, 'pagead2.googlesyndication.com') === false &&
|
|
strpos($html, 'adsbygoogle.js') === false) {
|
|
return $html;
|
|
}
|
|
|
|
// Patrones para encontrar etiquetas de script de AdSense
|
|
$patterns = array(
|
|
// Buscar etiquetas de script async para AdSense
|
|
'/<script\s+async\s+src=["\']https:\/\/pagead2\.googlesyndication\.com\/pagead\/js\/adsbygoogle\.js[^"\']*["\']\s*(?:crossorigin=["\']anonymous["\'])?\s*><\/script>/i',
|
|
|
|
// Buscar etiquetas de script sin async
|
|
'/<script\s+src=["\']https:\/\/pagead2\.googlesyndication\.com\/pagead\/js\/adsbygoogle\.js[^"\']*["\']\s*(?:crossorigin=["\']anonymous["\'])?\s*><\/script>/i',
|
|
|
|
// Buscar scripts inline de adsbygoogle.push
|
|
'/<script>\s*\(adsbygoogle\s*=\s*window\.adsbygoogle\s*\|\|\s*\[\]\)\.push\(\{[^}]*\}\);\s*<\/script>/is',
|
|
);
|
|
|
|
// Reemplazar scripts async de AdSense con versiones retrasadas
|
|
$replacements = array(
|
|
// Reemplazar etiqueta de script async con atributo data para carga retrasada
|
|
'<script type="text/plain" data-adsense-script src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js" crossorigin="anonymous"></script>',
|
|
|
|
// Reemplazar etiqueta de script no-async
|
|
'<script type="text/plain" data-adsense-script src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js" crossorigin="anonymous"></script>',
|
|
|
|
// Reemplazar scripts de push inline con versiones retrasadas
|
|
'<script type="text/plain" data-adsense-push>$0</script>',
|
|
);
|
|
|
|
// Primera pasada: reemplazar etiquetas de script
|
|
$html = preg_replace($patterns[0], $replacements[0], $html);
|
|
$html = preg_replace($patterns[1], $replacements[1], $html);
|
|
|
|
// Segunda pasada: reemplazar llamadas inline de push
|
|
$html = preg_replace_callback(
|
|
'/<script>\s*\(adsbygoogle\s*=\s*window\.adsbygoogle\s*\|\|\s*\[\]\)\.push\(\{[^}]*\}\);\s*<\/script>/is',
|
|
function($matches) {
|
|
return '<script type="text/plain" data-adsense-push>' . $matches[0] . '</script>';
|
|
},
|
|
$html
|
|
);
|
|
|
|
// Agregar comentario para indicar que se procesó (solo en modo debug)
|
|
if (defined('WP_DEBUG') && WP_DEBUG) {
|
|
$html = str_replace('</body>', '<!-- Scripts de AdSense retrasados por Apus Theme --></body>', $html);
|
|
}
|
|
|
|
return $html;
|
|
}
|
|
|
|
/**
|
|
* Agrega script inline para inicializar AdSense retrasado
|
|
*
|
|
* Esto agrega un pequeño script inline que marca AdSense como listo para cargar
|
|
* después de que adsense-loader.js ha sido enqueued.
|
|
*/
|
|
function apus_add_adsense_init_script() {
|
|
$delay_enabled = apus_get_option('apus_adsense_delay_enabled', '1');
|
|
|
|
if ($delay_enabled !== '1' || is_admin()) {
|
|
return;
|
|
}
|
|
|
|
?>
|
|
<script>
|
|
// Inicializar flag de retardo de AdSense
|
|
window.apusAdsenseDelayed = true;
|
|
</script>
|
|
<?php
|
|
}
|
|
add_action('wp_head', 'apus_add_adsense_init_script', 1);
|
|
|
|
/**
|
|
* INSTRUCCIONES DE USO:
|
|
*
|
|
* Para activar el retardo de carga de AdSense:
|
|
* 1. Ir al panel de opciones del tema (Dashboard > Apus Theme Options)
|
|
* 2. En la sección "Performance", activar la opción "Delay AdSense Loading"
|
|
* 3. Guardar cambios
|
|
*
|
|
* Comportamiento:
|
|
* - Los scripts de AdSense NO se cargarán hasta que el usuario:
|
|
* * Haga scroll en la página
|
|
* * Haga click en cualquier parte
|
|
* * Toque la pantalla (móviles)
|
|
* * Mueva el mouse
|
|
* * Presione una tecla
|
|
* - Si no hay interacción, los scripts se cargarán después de 5 segundos
|
|
*
|
|
* Beneficios:
|
|
* - Mejora significativa en Core Web Vitals (FID, TBT)
|
|
* - Reduce el tiempo de carga inicial de la página
|
|
* - No afecta la monetización (los ads se siguen mostrando)
|
|
* - Sin layout shifts al cargar los ads
|
|
*
|
|
* Para desactivar:
|
|
* - Desmarcar la opción en el panel de opciones del tema
|
|
* - Los scripts de AdSense se cargarán normalmente
|
|
*/
|