- proposal.md: define problem and expected changes - design.md: 9 technical decisions with rationale - spec.md: complete GIVEN/WHEN/THEN scenarios - tasks.md: implementation tasks with dependencies Features specified: - 7 ad insertion locations (H2, H3, p, img, lists, blockquotes, tables) - 5 density modes (legacy, conservative, balanced, aggressive, custom) - 2 selection strategies (position vs priority) - Deterministic probability with daily seed - Backward compatibility with legacy fields 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
130 lines
5.4 KiB
Markdown
130 lines
5.4 KiB
Markdown
# Tasks: Implementacion de In-Content Ads Avanzados
|
|
|
|
## Diagrama de Dependencias
|
|
|
|
```
|
|
1.1 ──┬──> 1.3 ──┬──> 2.x FormBuilder ──> 4.x
|
|
1.2 ──┘ │
|
|
└──> 3.x Renderer ──────> 4.x
|
|
│
|
|
v
|
|
5.x Docs
|
|
```
|
|
|
|
---
|
|
|
|
## 1. Schema JSON - Nuevos campos
|
|
|
|
**Prerequisitos:** Ninguno
|
|
|
|
- [ ] 1.1 Agregar grupo `incontent_advanced` con priority 69 al schema JSON
|
|
- [ ] 1.2 Agregar todos los campos definidos en spec:
|
|
- [ ] incontent_mode (select: legacy/conservative/balanced/aggressive/custom)
|
|
- [ ] incontent_after_h2_enabled + probability
|
|
- [ ] incontent_after_h3_enabled + probability
|
|
- [ ] incontent_after_paragraphs_enabled + probability (ubicacion tradicional)
|
|
- [ ] incontent_after_images_enabled + probability
|
|
- [ ] incontent_after_lists_enabled + probability
|
|
- [ ] incontent_after_blockquotes_enabled + probability
|
|
- [ ] incontent_after_tables_enabled + probability
|
|
- [ ] incontent_max_total_ads (1-15)
|
|
- [ ] incontent_min_spacing (2-6)
|
|
- [ ] incontent_format
|
|
- [ ] incontent_priority_mode (position/priority)
|
|
- [ ] 1.3 Sincronizar schema con BD via WP-CLI: `wp roi-theme sync-component adsense-placement`
|
|
|
|
---
|
|
|
|
## 2. FormBuilder Admin - Nueva UI
|
|
|
|
**Prerequisitos:** 1.3 completado
|
|
|
|
- [ ] 2.1 Crear metodo `buildInContentAdvancedGroup()` en AdsensePlacementFormBuilder
|
|
- [ ] 2.2 Implementar indicador de densidad (HTML + logica de color)
|
|
- [ ] 2.3 Implementar selector de modo con presets
|
|
- [ ] 2.4 Crear subseccion colapsable "Ubicaciones por Elemento" usando `<details>`
|
|
- [ ] 2.4.1 Toggle + probabilidad para H2
|
|
- [ ] 2.4.2 Toggle + probabilidad para H3
|
|
- [ ] 2.4.3 Toggle + probabilidad para parrafos (ubicacion tradicional)
|
|
- [ ] 2.4.4 Toggle + probabilidad para imagenes
|
|
- [ ] 2.4.5 Toggle + probabilidad para listas
|
|
- [ ] 2.4.6 Toggle + probabilidad para blockquotes
|
|
- [ ] 2.4.7 Toggle + probabilidad para tablas
|
|
- [ ] 2.5 Crear subseccion colapsable "Limites y Espaciado"
|
|
- [ ] 2.5.1 Select max_total_ads (1-15)
|
|
- [ ] 2.5.2 Select min_spacing (2-6)
|
|
- [ ] 2.6 Agregar warning visual para densidad alta (>10 ads)
|
|
- [ ] 2.7 Agregar banner de migracion para usuarios con config legacy activa
|
|
- [ ] 2.8 Mantener seccion legacy existente (modo "legacy" la usa)
|
|
- [ ] 2.9 Agregar mapeos en AdsensePlacementFieldMapper para todos los campos nuevos:
|
|
- [ ] incontent_mode
|
|
- [ ] incontent_after_h2_enabled + probability
|
|
- [ ] incontent_after_h3_enabled + probability
|
|
- [ ] incontent_after_paragraphs_enabled + probability
|
|
- [ ] incontent_after_images_enabled + probability
|
|
- [ ] incontent_after_lists_enabled + probability
|
|
- [ ] incontent_after_blockquotes_enabled + probability
|
|
- [ ] incontent_after_tables_enabled + probability
|
|
- [ ] incontent_max_total_ads
|
|
- [ ] incontent_min_spacing
|
|
- [ ] incontent_format
|
|
- [ ] incontent_priority_mode
|
|
- [ ] 2.10 Implementar logica JavaScript:
|
|
- [ ] 2.10.1 Auto-switch a "custom" al modificar campos (con toast informativo)
|
|
- [ ] 2.10.2 Modal de confirmacion al cambiar de "custom" a preset
|
|
- [ ] 2.10.3 Actualizar indicador de densidad en tiempo real
|
|
|
|
---
|
|
|
|
## 3. Renderer - Logica de insercion mejorada
|
|
|
|
**Prerequisitos:** 1.3 completado
|
|
|
|
- [ ] 3.1 Crear/modificar ContentAdInjector service con nuevo algoritmo
|
|
- [ ] 3.1.1 Implementar PASO 0: Validar min_content_length
|
|
- [ ] 3.1.2 Implementar PASO 1: Escaneo con regex multiple
|
|
```php
|
|
preg_split('/(<\/(?:p|h[2-3]|figure|ul|ol|table|blockquote)>)/i', ...)
|
|
```
|
|
- [ ] 3.1.3 Implementar deteccion de `<img>` standalone (no dentro de figure)
|
|
- [ ] 3.1.4 Implementar validacion de listas (usar substr_count, minimo 3 items)
|
|
- [ ] 3.2 Implementar PASO 2: Filtrado por configuracion (enabled flags)
|
|
- [ ] 3.3 Implementar PASO 3: Probabilidad deterministica
|
|
- [ ] 3.3.1 Calcular seed: `crc32(post_id . date('Y-m-d'))`
|
|
- [ ] 3.3.2 Usar `mt_srand(seed)` + `mt_rand(1, 100)`
|
|
- [ ] 3.4 Implementar PASO 4-5: Filtrado y seleccion (segun incontent_priority_mode)
|
|
- [ ] 3.4.1 Definir constantes de prioridad (H2=10, p=8, H3=7, img=6, lists=5, bq=4, table=3)
|
|
- [ ] 3.4.2 Implementar modo "position": espaciado primero, luego prioridad
|
|
- [ ] 3.4.3 Implementar modo "priority": prioridad primero, luego espaciado
|
|
- [ ] 3.4.4 Aplicar limite max_total_ads
|
|
- [ ] 3.4.5 Reordenar resultado final por posicion DOM
|
|
- [ ] 3.5 Implementar PASO 6: Insercion de ads
|
|
- [ ] 3.6 Implementar logica de precedencia legacy vs nuevo sistema
|
|
- [ ] 3.6.1 Si incontent_mode == "legacy", usar campos del grupo behavior
|
|
- [ ] 3.6.2 Si incontent_mode != "legacy", usar incontent_advanced
|
|
|
|
---
|
|
|
|
## 4. Validacion y Testing
|
|
|
|
**Prerequisitos:** 2.x y 3.x completados
|
|
|
|
- [ ] 4.1 Ejecutar `validate-architecture.php adsense-placement`
|
|
- [ ] 4.2 Probar en post con contenido variado (H2, H3, images, lists, tables)
|
|
- [ ] 4.3 Verificar que seed deterministico funciona (mismas posiciones mismo dia)
|
|
- [ ] 4.4 Verificar que espaciado minimo se respeta
|
|
- [ ] 4.5 Verificar que limite max_total_ads se respeta
|
|
- [ ] 4.6 Verificar que modo legacy sigue funcionando
|
|
- [ ] 4.7 Verificar que delay de carga sigue funcionando
|
|
- [ ] 4.8 Probar indicador de densidad en admin
|
|
- [ ] 4.9 Verificar ambos modos de priority_mode (position vs priority)
|
|
|
|
---
|
|
|
|
## 5. Documentacion
|
|
|
|
**Prerequisitos:** 4.x completado
|
|
|
|
- [ ] 5.1 Crear spec.md final en `openspec/specs/adsense-placement/`
|
|
- [ ] 5.2 Archivar este change: `openspec archive add-advanced-incontent-ads`
|