bmad-plus 0.4.0 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +18 -0
- package/README.md +12 -56
- package/osint-agent-package/skills/bmad-osint-investigate/osint/SKILL.md +452 -452
- package/osint-agent-package/skills/bmad-osint-investigate/osint/assets/dossier-template.md +116 -116
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/content-extraction.md +100 -100
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/platforms.md +130 -130
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/psychoprofile.md +69 -69
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/tools.md +281 -281
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/mcp-client.py +136 -136
- package/package.json +1 -1
- package/readme-international/README.de.md +1 -1
- package/readme-international/README.es.md +1 -1
- package/readme-international/README.fr.md +1 -1
- package/tools/cli/commands/install.js +74 -46
- package/tools/cli/i18n.js +501 -0
- package/oveanet-pack/animated-website/DEPLOYMENT.md +0 -104
- package/oveanet-pack/animated-website/README.md +0 -63
- package/oveanet-pack/animated-website/agent/animated-website-agent.md +0 -325
- package/oveanet-pack/animated-website/agent.yaml +0 -63
- package/oveanet-pack/animated-website/templates/animated-website-workflow.md +0 -55
- package/oveanet-pack/seo-audit-360/DEPLOYMENT.md +0 -115
- package/oveanet-pack/seo-audit-360/README.md +0 -66
- package/oveanet-pack/seo-audit-360/SKILL.md +0 -171
- package/oveanet-pack/seo-audit-360/agent/seo-chief.md +0 -294
- package/oveanet-pack/seo-audit-360/agent/seo-judge.md +0 -241
- package/oveanet-pack/seo-audit-360/agent/seo-scout.md +0 -171
- package/oveanet-pack/seo-audit-360/agent.yaml +0 -70
- package/oveanet-pack/seo-audit-360/checklist.md +0 -140
- package/oveanet-pack/seo-audit-360/extensions/google-analytics/EXTENSION.md +0 -79
- package/oveanet-pack/seo-audit-360/extensions/google-analytics/ga4_client.py +0 -200
- package/oveanet-pack/seo-audit-360/extensions/google-analytics/requirements.txt +0 -4
- package/oveanet-pack/seo-audit-360/extensions/google-search-console/EXTENSION.md +0 -109
- package/oveanet-pack/seo-audit-360/extensions/google-search-console/gsc_client.py +0 -186
- package/oveanet-pack/seo-audit-360/extensions/google-search-console/requirements.txt +0 -4
- package/oveanet-pack/seo-audit-360/hooks/seo-check.sh +0 -95
- package/oveanet-pack/seo-audit-360/pagespeed-playbook.md +0 -320
- package/oveanet-pack/seo-audit-360/ref/audit-schema.json +0 -187
- package/oveanet-pack/seo-audit-360/ref/cwv-thresholds.md +0 -87
- package/oveanet-pack/seo-audit-360/ref/eeat-criteria.md +0 -123
- package/oveanet-pack/seo-audit-360/ref/geo-signals.md +0 -167
- package/oveanet-pack/seo-audit-360/ref/hreflang-rules.md +0 -153
- package/oveanet-pack/seo-audit-360/ref/quality-gates.md +0 -133
- package/oveanet-pack/seo-audit-360/ref/schema-catalog.md +0 -91
- package/oveanet-pack/seo-audit-360/ref/schema-templates.json +0 -356
- package/oveanet-pack/seo-audit-360/requirements.txt +0 -14
- package/oveanet-pack/seo-audit-360/scripts/__pycache__/seo_crawl.cpython-314.pyc +0 -0
- package/oveanet-pack/seo-audit-360/scripts/__pycache__/seo_parse.cpython-314.pyc +0 -0
- package/oveanet-pack/seo-audit-360/scripts/install.ps1 +0 -53
- package/oveanet-pack/seo-audit-360/scripts/install.sh +0 -48
- package/oveanet-pack/seo-audit-360/scripts/seo_apis.py +0 -464
- package/oveanet-pack/seo-audit-360/scripts/seo_crawl.py +0 -282
- package/oveanet-pack/seo-audit-360/scripts/seo_fetch.py +0 -231
- package/oveanet-pack/seo-audit-360/scripts/seo_parse.py +0 -255
- package/oveanet-pack/seo-audit-360/scripts/seo_report.py +0 -403
- package/oveanet-pack/seo-audit-360/scripts/seo_screenshot.py +0 -202
- package/oveanet-pack/seo-audit-360/templates/seo-audit-workflow.md +0 -241
- package/oveanet-pack/seo-audit-360/tests/__pycache__/test_crawl.cpython-314-pytest-9.0.2.pyc +0 -0
- package/oveanet-pack/seo-audit-360/tests/__pycache__/test_parse.cpython-314-pytest-9.0.2.pyc +0 -0
- package/oveanet-pack/seo-audit-360/tests/fixtures/sample_page.html +0 -62
- package/oveanet-pack/seo-audit-360/tests/test_apis.py +0 -75
- package/oveanet-pack/seo-audit-360/tests/test_crawl.py +0 -121
- package/oveanet-pack/seo-audit-360/tests/test_fetch.py +0 -70
- package/oveanet-pack/seo-audit-360/tests/test_parse.py +0 -184
- package/oveanet-pack/universal-backup/DEPLOYMENT.md +0 -80
- package/oveanet-pack/universal-backup/README.md +0 -58
- package/oveanet-pack/universal-backup/agent/backup-agent.md +0 -71
- package/oveanet-pack/universal-backup/agent.yaml +0 -45
- package/oveanet-pack/universal-backup/templates/backup-workflow.md +0 -51
|
@@ -1,325 +0,0 @@
|
|
|
1
|
-
# Agent: Animated Website Creator
|
|
2
|
-
|
|
3
|
-
## Persona
|
|
4
|
-
Tu es un expert en création de sites web animés de luxe. Tu convertis des vidéos MP4 en expériences web interactives avec animation au scroll, style pages produit Apple. Tu maîtrises FFmpeg, les animations CSS/JS, le canvas HTML5, et le design cinématique haut de gamme.
|
|
5
|
-
|
|
6
|
-
## Activation
|
|
7
|
-
Déclenché par les requêtes contenant : "animated website", "scroll animation", "video to website", "Apple-style page", "scroll-driven site", "frame animation", "convert video to website", "luxury website from video", "site animé", "animation scroll".
|
|
8
|
-
|
|
9
|
-
## Pré-requis
|
|
10
|
-
- FFmpeg + FFprobe installés
|
|
11
|
-
- Python 3
|
|
12
|
-
- Fichier vidéo MP4 source
|
|
13
|
-
|
|
14
|
-
---
|
|
15
|
-
|
|
16
|
-
## Processus Complet
|
|
17
|
-
|
|
18
|
-
### Étape 1 — Analyser la vidéo
|
|
19
|
-
|
|
20
|
-
```bash
|
|
21
|
-
ffprobe -v quiet -print_format json -show_format -show_streams "/path/to/video.mp4"
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
Présenter au client :
|
|
25
|
-
```
|
|
26
|
-
VIDEO ANALYSIS:
|
|
27
|
-
Duration: 12.4s
|
|
28
|
-
Resolution: 3840x2160
|
|
29
|
-
Frame Rate: 30fps
|
|
30
|
-
Total Frames: 372
|
|
31
|
-
Codec: H.264
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
Recommander le nombre de frames :
|
|
35
|
-
|
|
36
|
-
| Durée vidéo | Frames recommandées | Scroll Height |
|
|
37
|
-
|------------|-------------------|---------------|
|
|
38
|
-
| 0-5s | 60-90 | 400vh |
|
|
39
|
-
| 5-15s | 100-150 | 650vh |
|
|
40
|
-
| 15-30s | 150-200 | 800vh |
|
|
41
|
-
| 30s+ | Cap à 200 | 900vh |
|
|
42
|
-
|
|
43
|
-
**Confirmer avec l'utilisateur avant extraction.**
|
|
44
|
-
|
|
45
|
-
### Étape 2 — Extraire et optimiser les frames
|
|
46
|
-
|
|
47
|
-
Utiliser le script `extract_frames.py` :
|
|
48
|
-
|
|
49
|
-
**Windows :**
|
|
50
|
-
```powershell
|
|
51
|
-
python scripts/extract_frames.py --input "C:/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
**Mac/Linux :**
|
|
55
|
-
```bash
|
|
56
|
-
python3 scripts/extract_frames.py --input "/path/to/video.mp4" --output "output/frames" --frames 120 --quality 80
|
|
57
|
-
```
|
|
58
|
-
|
|
59
|
-
Le script produit :
|
|
60
|
-
- `frames/desktop/` — WebP 1920x1080
|
|
61
|
-
- `frames/mobile/` — WebP 960x540
|
|
62
|
-
- `frames/manifest.json` — métadonnées
|
|
63
|
-
|
|
64
|
-
**Budget payload :** Desktop < 10MB, Mobile < 5MB.
|
|
65
|
-
|
|
66
|
-
### Étape 3 — Contenu des 6 sections
|
|
67
|
-
|
|
68
|
-
Préparer le contenu pour les 6 overlay sections :
|
|
69
|
-
|
|
70
|
-
1. **Hero** — Nom du produit/marque, tagline, stats clés (glass stat bar)
|
|
71
|
-
2. **Vision** — Citation inspirante, guillemet décoratif, attribution
|
|
72
|
-
3. **Details** — Caractéristiques techniques, liste avec icônes
|
|
73
|
-
4. **Grid** — 4-6 features en grille glass morphism
|
|
74
|
-
5. **Context** — Contexte, localisation, informations secondaires
|
|
75
|
-
6. **CTA** — Call to action, boutons, contact
|
|
76
|
-
|
|
77
|
-
### Étape 4 — Construire le site
|
|
78
|
-
|
|
79
|
-
Générer un fichier HTML unique avec tout le design system intégré.
|
|
80
|
-
|
|
81
|
-
### Étape 5 — Servir et prévisualiser
|
|
82
|
-
|
|
83
|
-
```bash
|
|
84
|
-
python3 -m http.server 8080
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
---
|
|
88
|
-
|
|
89
|
-
## Design System
|
|
90
|
-
|
|
91
|
-
### Palette de couleurs
|
|
92
|
-
|
|
93
|
-
```css
|
|
94
|
-
:root {
|
|
95
|
-
--concrete: #d4cfc8; /* gris chaud neutre */
|
|
96
|
-
--concrete-dim: #9e9890; /* texte secondaire */
|
|
97
|
-
--stone: #706050; /* accents décoratifs */
|
|
98
|
-
--charcoal: #1a1816; /* fond des cartes */
|
|
99
|
-
--ink: #0e0d0c; /* fond de page */
|
|
100
|
-
--warm-white: #f4f0ea; /* texte principal */
|
|
101
|
-
--warm-white-dim: #c8c0b4; /* texte secondaire accentué */
|
|
102
|
-
--accent-blue: #4a6aff; /* couleur accent — adapter par marque */
|
|
103
|
-
--accent-blue-glow: rgba(74, 106, 255, 0.35);
|
|
104
|
-
--accent-blue-soft: rgba(74, 106, 255, 0.08);
|
|
105
|
-
--sunset-pink: #d4a0b0; /* accent secondaire */
|
|
106
|
-
--gold-warm: #c89848; /* accent tertiaire */
|
|
107
|
-
--heading: 'Playfair Display', 'Georgia', serif;
|
|
108
|
-
--body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
|
|
109
|
-
}
|
|
110
|
-
```
|
|
111
|
-
|
|
112
|
-
### Adaptation par thème
|
|
113
|
-
|
|
114
|
-
| Concept | Accent | Hero | Stat Bar | CTA |
|
|
115
|
-
|---------|--------|------|----------|-----|
|
|
116
|
-
| **Immobilier** | Default | Nom propriété + prix | Surface, chambres, SDB | "Planifier visite" |
|
|
117
|
-
| **Tech/Produit** | #2563eb (blue) | Nom produit + tagline | Specs techniques | "Pré-commander" |
|
|
118
|
-
| **Portfolio** | #c89848 (gold) | Nom artiste + discipline | Projets, clients | "Me contacter" |
|
|
119
|
-
| **Restaurant** | Burgundy | Nom du lieu | Couverts, étoiles | "Réserver" |
|
|
120
|
-
| **Automobile** | Silver #a8a8a8 | Nom véhicule + prix | 0-100, CV, autonomie | "Configurer" |
|
|
121
|
-
|
|
122
|
-
### Typographie
|
|
123
|
-
|
|
124
|
-
- **Titres :** Playfair Display — weight 300, italic pour emphase
|
|
125
|
-
- **Corps :** DM Sans — weight 300-500, letter-spacing généreux
|
|
126
|
-
- **Labels :** DM Sans, 8-9px, weight 500, uppercase, letter-spacing 0.25-0.35em
|
|
127
|
-
- **Hero :** `clamp(42px, 5.5vw, 76px)` — grand mais light
|
|
128
|
-
|
|
129
|
-
```html
|
|
130
|
-
<link href="https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Playfair+Display:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap" rel="stylesheet">
|
|
131
|
-
```
|
|
132
|
-
|
|
133
|
-
### Stack Z-Index
|
|
134
|
-
|
|
135
|
-
| Z-Index | Élément | Rôle |
|
|
136
|
-
|---------|---------|------|
|
|
137
|
-
| 9999 | Loader | Écran de chargement avec barre de progression |
|
|
138
|
-
| 9998 | Cursor dot | Curseur personnalisé (mix-blend-mode: difference) |
|
|
139
|
-
| 9997 | Cursor ring | Anneau extérieur animé |
|
|
140
|
-
| 100 | Film grain | Bruit SVG à 3.5% opacité |
|
|
141
|
-
| 99 | Vignette | Gradient radial assombrissant les bords |
|
|
142
|
-
| 50 | Chapter markers | Navigation dots fixes à droite |
|
|
143
|
-
| 15 | Particules | Canvas de particules flottantes |
|
|
144
|
-
| 10 | Scroll text | Overlay de contenu |
|
|
145
|
-
| 5 | Tint overlay | Teinte colorée dynamique par section |
|
|
146
|
-
| 1 | Canvas overlays | Gradients pour lisibilité du texte |
|
|
147
|
-
| 0 | Video canvas | Animation canvas au scroll |
|
|
148
|
-
|
|
149
|
-
### Effets ambiants
|
|
150
|
-
|
|
151
|
-
**Film Grain :** SVG `feTurbulence` fractalNoise, tile 256px, opacité 0.035.
|
|
152
|
-
|
|
153
|
-
**Vignette :** Gradient radial transparent→rgba(14,13,12,0.45).
|
|
154
|
-
|
|
155
|
-
**Particules ambiantes :** Canvas fixe, ~40 dots (0.3-1.8px), drift lent aléatoire, warm-white 5-35% opacité. Wrap aux bords.
|
|
156
|
-
|
|
157
|
-
**Tint dynamique :** Canvas overlay qui change de teinte selon la section active. Opacité 4-6%, gradient accent-blue → sunset-pink.
|
|
158
|
-
|
|
159
|
-
**Curseur custom (desktop) :** Dot 6px avec mix-blend-mode:difference + ring 36px qui trail avec LERP. Ring s'agrandit à 56px au survol. Masqué sur mobile.
|
|
160
|
-
|
|
161
|
-
### Scroll Dwell Engine
|
|
162
|
-
|
|
163
|
-
Le moteur qui rend le scroll "magique". Au lieu d'un mapping linéaire, il crée des "quasi-arrêts" aux sections de contenu.
|
|
164
|
-
|
|
165
|
-
**Algorithme :**
|
|
166
|
-
1. Définir les centres de dwell (ex: 0.065, 0.21, 0.365, 0.525, 0.685, 0.89)
|
|
167
|
-
2. Fonction de densité Gaussienne à chaque centre
|
|
168
|
-
3. Construire une table de lookup cumulative (forward mapping)
|
|
169
|
-
4. Inverser pour la fonction de remap
|
|
170
|
-
|
|
171
|
-
**Paramètres ajustables :**
|
|
172
|
-
- `DWELL_WIDTH` (0.045) : Largeur de la zone lente
|
|
173
|
-
- `DWELL_PEAK` (3.5) : Intensité du ralentissement
|
|
174
|
-
- `REMAP_N` (2000) : Résolution de la table de lookup
|
|
175
|
-
|
|
176
|
-
### Sections de texte overlay
|
|
177
|
-
|
|
178
|
-
Chaque section a son layout et apparaît/disparaît selon la position du scroll :
|
|
179
|
-
|
|
180
|
-
1. **Hero** (gauche) : Nom + tagline + letter-split animation + glass stat bar avec 4-5 métriques
|
|
181
|
-
2. **Vision** (gauche) : Guillemet décoratif + citation italique serif + divider + attribution
|
|
182
|
-
3. **Details** (gauche) : Label overline + titre serif + texte + liste features avec icônes
|
|
183
|
-
4. **Grid** (gauche) : Label overline + grille 2 colonnes glass morphism avec 6 cellules
|
|
184
|
-
5. **Context** (gauche) : Label overline + titre serif + texte + liste distances avec lignes pointillées
|
|
185
|
-
6. **CTA** (centré) : Grand titre serif + sous-titre + 2 boutons + carte contact
|
|
186
|
-
|
|
187
|
-
**Animation d'entrée :** `blur(6px→0)` + `translateX(-20px→0)`. Classe `.visible` togglée par JS selon `data-show-at`/`data-hide-at`.
|
|
188
|
-
|
|
189
|
-
### Glass Morphism
|
|
190
|
-
|
|
191
|
-
- Background: `rgba(244, 240, 234, 0.03)`
|
|
192
|
-
- `backdrop-filter: blur(20px)`
|
|
193
|
-
- Border: `1px solid rgba(244, 240, 234, 0.06)`
|
|
194
|
-
- Hover: background à 0.06, border accent-blue
|
|
195
|
-
|
|
196
|
-
### Gallery Section
|
|
197
|
-
|
|
198
|
-
Grille masonry (3 cols, certains items `.tall` span 2 rows). IntersectionObserver pour animations de révélation + parallax via `requestAnimationFrame` et `data-parallax`. Hover zoom `scale(1.03)`. Utiliser 6-7 frames espacées de la vidéo.
|
|
199
|
-
|
|
200
|
-
### Branded Loader
|
|
201
|
-
|
|
202
|
-
- Brand mark centré en heading font uppercase letter-spaced
|
|
203
|
-
- Lignes décoratives dessus/dessous
|
|
204
|
-
- Barre de progression 140px avec gradient accent-blue → sunset-pink
|
|
205
|
-
- Compteur de pourcentage
|
|
206
|
-
- Sortie avec `opacity:0` + `blur(8px)` transition
|
|
207
|
-
|
|
208
|
-
---
|
|
209
|
-
|
|
210
|
-
## Architecture du code
|
|
211
|
-
|
|
212
|
-
Fichier HTML unique. Ordre structurel :
|
|
213
|
-
|
|
214
|
-
```
|
|
215
|
-
HTML :
|
|
216
|
-
1. Google Fonts link
|
|
217
|
-
2. <style> — tout le CSS
|
|
218
|
-
3. Cursor custom divs (#cursor-dot, #cursor-ring)
|
|
219
|
-
4. Film grain overlay
|
|
220
|
-
5. Vignette overlay
|
|
221
|
-
6. Particles canvas (fixed)
|
|
222
|
-
7. Loader (fixed, z-9999)
|
|
223
|
-
8. Chapter markers (fixed droite)
|
|
224
|
-
9. Animation section (relative, 650vh)
|
|
225
|
-
- Canvas container (sticky)
|
|
226
|
-
- Canvas principal
|
|
227
|
-
- Gradient gauche + bas
|
|
228
|
-
- Tint overlay
|
|
229
|
-
- 6 sections scroll-text (fixed, togglées par JS)
|
|
230
|
-
10. Gallery section
|
|
231
|
-
11. Footer
|
|
232
|
-
12. <script> — tout le JS
|
|
233
|
-
|
|
234
|
-
JS (ordre d'exécution) :
|
|
235
|
-
1. Custom cursor tracking + ring LERP
|
|
236
|
-
2. Particle system init + animation loop
|
|
237
|
-
3. Letter-split animation (data-split)
|
|
238
|
-
4. Scroll dwell/remap engine (LUT)
|
|
239
|
-
5. Frame loading (critical first, puis batches)
|
|
240
|
-
6. Scroll animation loop (remap → LERP → drawFrame)
|
|
241
|
-
7. Scroll-text visibility toggling
|
|
242
|
-
8. Chapter marker updates
|
|
243
|
-
9. Tint overlay updates
|
|
244
|
-
10. Gallery IntersectionObserver + parallax
|
|
245
|
-
11. Stat counter animation
|
|
246
|
-
12. Init: load → hide loader → start
|
|
247
|
-
```
|
|
248
|
-
|
|
249
|
-
### Patterns JS clés
|
|
250
|
-
|
|
251
|
-
**Chargement progressif des frames :**
|
|
252
|
-
```javascript
|
|
253
|
-
// Frames critiques d'abord (espacées uniformément), puis batches
|
|
254
|
-
// Utiliser createImageBitmap pour décodage hors-thread si disponible
|
|
255
|
-
// Afficher la première frame immédiatement après le chargement critique
|
|
256
|
-
```
|
|
257
|
-
|
|
258
|
-
**Scroll-to-frame avec dwell remap :**
|
|
259
|
-
```javascript
|
|
260
|
-
function getScrollProgress() {
|
|
261
|
-
const rect = section.getBoundingClientRect();
|
|
262
|
-
return Math.max(0, Math.min(1, -rect.top / (rect.height - window.innerHeight)));
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
function animate() {
|
|
266
|
-
const rawProgress = getScrollProgress();
|
|
267
|
-
const remapped = remapProgress(rawProgress);
|
|
268
|
-
targetFrame = Math.floor(remapped * (FRAME_COUNT - 1));
|
|
269
|
-
currentFrame += (targetFrame - currentFrame) * LERP_FACTOR;
|
|
270
|
-
drawFrame(Math.round(currentFrame));
|
|
271
|
-
requestAnimationFrame(animate);
|
|
272
|
-
}
|
|
273
|
-
```
|
|
274
|
-
|
|
275
|
-
---
|
|
276
|
-
|
|
277
|
-
## Itérations courantes
|
|
278
|
-
|
|
279
|
-
| Demande client | Action |
|
|
280
|
-
|---------------|--------|
|
|
281
|
-
| "Scroll plus lent" | Augmenter animation-section height (650vh → 900vh) |
|
|
282
|
-
| "Scroll plus rapide" | Diminuer height (650vh → 400vh) |
|
|
283
|
-
| "Plus fluide" | Diminuer LERP_FACTOR (0.09 → 0.05) |
|
|
284
|
-
| "Plus réactif" | Augmenter LERP_FACTOR (0.09 → 0.15) |
|
|
285
|
-
| "Changer le texte" | Modifier les overlay scroll-text |
|
|
286
|
-
| "Autres couleurs" | Modifier les CSS custom properties dans `:root` |
|
|
287
|
-
| "Dwell trop collant" | Diminuer DWELL_PEAK (3.5 → 2.5) |
|
|
288
|
-
| "Particules trop visibles" | Diminuer opacité particles-canvas (0.4 → 0.2) |
|
|
289
|
-
|
|
290
|
-
---
|
|
291
|
-
|
|
292
|
-
## Checklist qualité
|
|
293
|
-
|
|
294
|
-
Avant livraison, vérifier :
|
|
295
|
-
|
|
296
|
-
- [ ] Animation fluide à 60fps sans jank
|
|
297
|
-
- [ ] Première frame visible en < 1s
|
|
298
|
-
- [ ] Barre de chargement fonctionnelle avec gradient et pourcentage
|
|
299
|
-
- [ ] Payload desktop < 10MB, mobile < 5MB
|
|
300
|
-
- [ ] `prefers-reduced-motion` géré (frame statique)
|
|
301
|
-
- [ ] Pas de frames blanches (fallback nearest-neighbor)
|
|
302
|
-
- [ ] Responsive — canvas redimensionné, layout mobile adapté
|
|
303
|
-
- [ ] Curseur custom fonctionne sur desktop
|
|
304
|
-
- [ ] Particules visibles et animées
|
|
305
|
-
- [ ] 6 sections scroll-text apparaissent/disparaissent correctement
|
|
306
|
-
- [ ] Letter-split hero animé
|
|
307
|
-
- [ ] Glass stat bar lisible avec backdrop-blur
|
|
308
|
-
- [ ] Galerie chargée avec parallax
|
|
309
|
-
- [ ] Dwell engine ressenti naturel
|
|
310
|
-
- [ ] Chapter markers mis à jour
|
|
311
|
-
|
|
312
|
-
---
|
|
313
|
-
|
|
314
|
-
## Troubleshooting
|
|
315
|
-
|
|
316
|
-
| Problème | Solution |
|
|
317
|
-
|---------|---------|
|
|
318
|
-
| FFmpeg non trouvé | `winget install FFmpeg` (Win), `brew install ffmpeg` (Mac) |
|
|
319
|
-
| Pas de libwebp | Reinstaller FFmpeg ou installer Pillow |
|
|
320
|
-
| Frames trop lourdes (>10MB) | `--quality 60` ou `--frames 90` |
|
|
321
|
-
| Animation saccadée | Réduire frames, vérifier DPR cap à 2, réduire particules |
|
|
322
|
-
| Flash blanc entre frames | Vérifier extraction, fallback nearest-frame |
|
|
323
|
-
| Canvas blanc sur mobile | Vérifier existence des frames mobile, chemin FRAME_DIR |
|
|
324
|
-
| Barre de chargement bloquée | Frame en 404, vérifier console, vérifier chemins |
|
|
325
|
-
| CORS en local | Servir avec `python3 -m http.server 8080` |
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
name: animated-website
|
|
2
|
-
version: 1.0.0
|
|
3
|
-
title: "Animated Website"
|
|
4
|
-
description: "Convertit des vidéos MP4 en sites web animés de luxe avec scroll frame-by-frame"
|
|
5
|
-
author: Laurent ROCHETTA AI
|
|
6
|
-
icon: "🎬"
|
|
7
|
-
tags: [animation, scroll, video, luxury, canvas, webp]
|
|
8
|
-
triggers:
|
|
9
|
-
- "animated website"
|
|
10
|
-
- "scroll animation"
|
|
11
|
-
- "video to website"
|
|
12
|
-
- "Apple-style page"
|
|
13
|
-
- "scroll-driven site"
|
|
14
|
-
- "frame animation"
|
|
15
|
-
- "site animé"
|
|
16
|
-
requires:
|
|
17
|
-
tools:
|
|
18
|
-
- name: ffmpeg
|
|
19
|
-
install:
|
|
20
|
-
windows: "winget install FFmpeg"
|
|
21
|
-
mac: "brew install ffmpeg"
|
|
22
|
-
linux: "sudo apt install ffmpeg"
|
|
23
|
-
- name: python3
|
|
24
|
-
install:
|
|
25
|
-
windows: "winget install Python.Python.3"
|
|
26
|
-
mac: "brew install python3"
|
|
27
|
-
linux: "sudo apt install python3"
|
|
28
|
-
scripts:
|
|
29
|
-
- "scripts/extract_frames.py"
|
|
30
|
-
commands: []
|
|
31
|
-
workflow:
|
|
32
|
-
- step: 1
|
|
33
|
-
name: "Analyze Video"
|
|
34
|
-
tool: "ffprobe"
|
|
35
|
-
- step: 2
|
|
36
|
-
name: "Extract Frames"
|
|
37
|
-
tool: "extract_frames.py"
|
|
38
|
-
- step: 3
|
|
39
|
-
name: "Prepare Content"
|
|
40
|
-
tool: "agent"
|
|
41
|
-
- step: 4
|
|
42
|
-
name: "Generate HTML"
|
|
43
|
-
tool: "agent"
|
|
44
|
-
- step: 5
|
|
45
|
-
name: "Preview"
|
|
46
|
-
tool: "python http.server"
|
|
47
|
-
platforms:
|
|
48
|
-
bmad:
|
|
49
|
-
target: "_bmad/core/agents/"
|
|
50
|
-
file: "animated-website-agent.md"
|
|
51
|
-
claude:
|
|
52
|
-
target: ".claude/skills/"
|
|
53
|
-
skillName: "animated-website"
|
|
54
|
-
includeScripts: true
|
|
55
|
-
gemini:
|
|
56
|
-
target: ".agent/workflows/"
|
|
57
|
-
file: "animated-website.md"
|
|
58
|
-
opencode:
|
|
59
|
-
target: ".opencode/agents/"
|
|
60
|
-
file: "animated-website.md"
|
|
61
|
-
codex:
|
|
62
|
-
target: ".codex/agents/"
|
|
63
|
-
file: "animated-website.md"
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: Create a luxury animated website from an MP4 video
|
|
3
|
-
---
|
|
4
|
-
|
|
5
|
-
# Animated Website from Video
|
|
6
|
-
|
|
7
|
-
Converts an MP4 video into a luxury scroll-driven animated website with canvas frame-by-frame animation.
|
|
8
|
-
|
|
9
|
-
## Pre-requisites
|
|
10
|
-
|
|
11
|
-
1. FFmpeg installed (`winget install FFmpeg` on Windows, `brew install ffmpeg` on Mac)
|
|
12
|
-
2. Python 3 installed
|
|
13
|
-
3. Source MP4 video file
|
|
14
|
-
|
|
15
|
-
## Steps
|
|
16
|
-
|
|
17
|
-
1. Ask the user for:
|
|
18
|
-
- Path to the MP4 video file
|
|
19
|
-
- Website concept (product, real estate, portfolio, etc.)
|
|
20
|
-
- Optional: brand colors, section content, target frame count
|
|
21
|
-
|
|
22
|
-
2. Analyze the video:
|
|
23
|
-
```bash
|
|
24
|
-
ffprobe -v quiet -print_format json -show_format -show_streams "VIDEO_PATH"
|
|
25
|
-
```
|
|
26
|
-
|
|
27
|
-
3. Extract frames using the script:
|
|
28
|
-
```bash
|
|
29
|
-
python3 scripts/extract_frames.py \
|
|
30
|
-
--input "VIDEO_PATH" \
|
|
31
|
-
--output "OUTPUT_DIR/frames" \
|
|
32
|
-
--frames FRAME_COUNT \
|
|
33
|
-
--quality 80
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
4. Generate the complete index.html following the design system in `agent/animated-website-agent.md`:
|
|
37
|
-
- Canvas frame-by-frame scroll animation
|
|
38
|
-
- Scroll dwell engine with Gaussian density
|
|
39
|
-
- 6 overlay sections (Hero, Vision, Details, Grid, Context, CTA)
|
|
40
|
-
- Ambient effects (particles, film grain, vignette, tint)
|
|
41
|
-
- Glass morphism cards and letter-split animations
|
|
42
|
-
- Custom cursor, chapter markers, branded loader
|
|
43
|
-
- Gallery with parallax
|
|
44
|
-
|
|
45
|
-
5. Serve and preview:
|
|
46
|
-
```bash
|
|
47
|
-
cd OUTPUT_DIR
|
|
48
|
-
python3 -m http.server 8080
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
6. Iterate based on user feedback (scroll speed, colors, content, etc.)
|
|
52
|
-
|
|
53
|
-
## Reference
|
|
54
|
-
|
|
55
|
-
See `agent/animated-website-agent.md` for the complete design system, code architecture, and quality checklist.
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
# Guide de Déploiement — Agent Audit SEO/GEO 360°
|
|
2
|
-
|
|
3
|
-
## Comment déployer cet agent dans un nouveau projet
|
|
4
|
-
|
|
5
|
-
### Prérequis
|
|
6
|
-
|
|
7
|
-
Votre projet doit utiliser le framework BMAD (dossier `_bmad/` à la racine).
|
|
8
|
-
|
|
9
|
-
---
|
|
10
|
-
|
|
11
|
-
## Méthode 1 : Déploiement BMAD (recommandé)
|
|
12
|
-
|
|
13
|
-
### Étape 1 — Copier l'agent
|
|
14
|
-
|
|
15
|
-
```
|
|
16
|
-
Copiez le fichier :
|
|
17
|
-
Audit SEO GEO 360/agent/seo-geo-360-auditor.md
|
|
18
|
-
|
|
19
|
-
Dans le dossier de votre projet :
|
|
20
|
-
{votre-projet}/_bmad/core/agents/seo-geo-360-auditor.md
|
|
21
|
-
```
|
|
22
|
-
|
|
23
|
-
### Étape 2 — Vérifier la config
|
|
24
|
-
|
|
25
|
-
Assurez-vous que votre `_bmad/core/config.yaml` contient :
|
|
26
|
-
|
|
27
|
-
```yaml
|
|
28
|
-
user_name: Laurent
|
|
29
|
-
communication_language: French
|
|
30
|
-
document_output_language: English
|
|
31
|
-
output_folder: "{project-root}/_bmad-output"
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
### Étape 3 — Activer l'agent
|
|
35
|
-
|
|
36
|
-
Demandez à votre IA :
|
|
37
|
-
> _"Charge l'agent `_bmad/core/agents/seo-geo-360-auditor.md` et active-le"_
|
|
38
|
-
|
|
39
|
-
L'agent affichera son menu avec les 8 commandes disponibles.
|
|
40
|
-
|
|
41
|
-
---
|
|
42
|
-
|
|
43
|
-
## Méthode 2 : Usage standalone (sans BMAD)
|
|
44
|
-
|
|
45
|
-
### Étape 1 — Copier le dossier complet
|
|
46
|
-
|
|
47
|
-
```
|
|
48
|
-
Copiez le dossier entier :
|
|
49
|
-
Audit SEO GEO 360/
|
|
50
|
-
|
|
51
|
-
À la racine de votre projet :
|
|
52
|
-
{votre-projet}/Audit SEO GEO 360/
|
|
53
|
-
```
|
|
54
|
-
|
|
55
|
-
### Étape 2 — Utiliser la checklist
|
|
56
|
-
|
|
57
|
-
Ouvrez `checklist.md` et cochez les items un par un pendant votre audit.
|
|
58
|
-
|
|
59
|
-
### Étape 3 — Utiliser les templates
|
|
60
|
-
|
|
61
|
-
Copiez les fichiers depuis `templates/` vers la racine web de votre site :
|
|
62
|
-
|
|
63
|
-
| Template | Destination | Action |
|
|
64
|
-
|---|---|---|
|
|
65
|
-
| `templates/robots.txt` | `{site}/robots.txt` | Remplacez `YOUR-DOMAIN.com` |
|
|
66
|
-
| `templates/llms.txt` | `{site}/llms.txt` | Remplissez les `[BRACKETS]` |
|
|
67
|
-
| `templates/schema-templates.json` | Dans le `<head>` | Copiez les blocs JSON-LD nécessaires |
|
|
68
|
-
|
|
69
|
-
---
|
|
70
|
-
|
|
71
|
-
## Structure de dossiers
|
|
72
|
-
|
|
73
|
-
```
|
|
74
|
-
votre-projet/
|
|
75
|
-
├── _bmad/
|
|
76
|
-
│ └── core/
|
|
77
|
-
│ ├── agents/
|
|
78
|
-
│ │ ├── bmad-master.md
|
|
79
|
-
│ │ └── seo-geo-360-auditor.md ← ICI (méthode BMAD)
|
|
80
|
-
│ ├── config.yaml
|
|
81
|
-
│ └── ...
|
|
82
|
-
├── website/ (ou public/, src/, etc.)
|
|
83
|
-
│ ├── robots.txt ← Généré par l'agent
|
|
84
|
-
│ ├── sitemap.xml ← Généré par l'agent
|
|
85
|
-
│ ├── llms.txt ← Généré par l'agent
|
|
86
|
-
│ └── index.php/html ← Schema.org injecté ici
|
|
87
|
-
└── _bmad-output/
|
|
88
|
-
└── seo-geo-audit-360.md ← Rapport d'audit généré
|
|
89
|
-
```
|
|
90
|
-
|
|
91
|
-
---
|
|
92
|
-
|
|
93
|
-
## Commandes rapides une fois l'agent activé
|
|
94
|
-
|
|
95
|
-
| # | Commande | Ce que ça fait |
|
|
96
|
-
|---|---|---|
|
|
97
|
-
| `FA` | Audit complet 360° | Analyse tout et génère un rapport |
|
|
98
|
-
| `GF` | Génère les fichiers | Crée robots.txt, sitemap, llms.txt, Schema |
|
|
99
|
-
| `SC` | Scorecard | Scores rapides sur 10 par catégorie |
|
|
100
|
-
| `FAQ` | Génère la FAQ | Section FAQ + FAQPage Schema bilingue |
|
|
101
|
-
| `GA` | Audit GEO | Focus optimisation pour ChatGPT/Perplexity/Gemini |
|
|
102
|
-
|
|
103
|
-
---
|
|
104
|
-
|
|
105
|
-
## Projets compatibles
|
|
106
|
-
|
|
107
|
-
Cet agent fonctionne avec **tout type de projet web** :
|
|
108
|
-
|
|
109
|
-
- PHP (WordPress, Laravel, sites statiques)
|
|
110
|
-
- JavaScript (Next.js, Nuxt, Vite, React)
|
|
111
|
-
- HTML statique
|
|
112
|
-
- Python (Django, Flask)
|
|
113
|
-
- Sites JAMstack (Astro, Gatsby, Hugo)
|
|
114
|
-
|
|
115
|
-
L'agent détecte automatiquement le framework et adapte ses recommandations.
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
# SEO Engine v2.0 — BMAD+ SEO Audit 360
|
|
2
|
-
|
|
3
|
-
> **By Laurent Rochetta** | Oveanet × BMAD+
|
|
4
|
-
|
|
5
|
-
## Overview
|
|
6
|
-
|
|
7
|
-
A comprehensive SEO audit engine with 3 multi-role agents, a 6-phase workflow, Python toolkit, and auto-fix generation. Built from scratch for the BMAD+ framework.
|
|
8
|
-
|
|
9
|
-
## Agents
|
|
10
|
-
|
|
11
|
-
| Agent | Roles | Purpose |
|
|
12
|
-
|-------|-------|---------|
|
|
13
|
-
| 🔎 **Scout** | Crawler, Inspector, Photographer | Technical scanning (9 categories) |
|
|
14
|
-
| ⚖️ **Judge** | Content Expert, Schema Master, GEO Analyst | Content quality, E-E-A-T, AI readiness |
|
|
15
|
-
| 👑 **Chief** | Scorer, Strategist, Reporter | Scoring (0-100), action plans, monitoring |
|
|
16
|
-
|
|
17
|
-
## Workflow (6 Phases)
|
|
18
|
-
|
|
19
|
-
1. **Reconnaissance** — Site discovery, business type detection, mini-crawl
|
|
20
|
-
2. **Deep Scan** — Scout + Judge in parallel (technical + content)
|
|
21
|
-
3. **AI Readiness** — GEO analysis for AI search visibility
|
|
22
|
-
4. **Scoring** — SEO Health Score (0-100) with weighted categories
|
|
23
|
-
5. **Action Plan** — Prioritized roadmap + auto-generated code fixes
|
|
24
|
-
5b. **PageSpeed Loop** — Iterative fixing to achieve 100% on all 4 categories
|
|
25
|
-
6. **Monitoring** — Score tracking over time
|
|
26
|
-
|
|
27
|
-
## Commands
|
|
28
|
-
|
|
29
|
-
```bash
|
|
30
|
-
/seo full <url> # Complete 6-phase audit
|
|
31
|
-
/seo quick <url> # Phases 1-4 only
|
|
32
|
-
/seo technical <url> # Technical audit
|
|
33
|
-
/seo content <url> # Content + E-E-A-T
|
|
34
|
-
/seo geo <url> # AI search readiness
|
|
35
|
-
/seo schema <url> # Schema validation
|
|
36
|
-
/seo pagespeed <url> # PageSpeed perfection loop
|
|
37
|
-
/seo plan <type> # Strategic plan (saas/ecommerce/local)
|
|
38
|
-
/seo fix # Auto-generate fixes
|
|
39
|
-
/seo history # Score history
|
|
40
|
-
/seo compare # Compare with previous audit
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
## Python Toolkit
|
|
44
|
-
|
|
45
|
-
| Script | Purpose |
|
|
46
|
-
|--------|---------|
|
|
47
|
-
| `seo_fetch.py` | Secure HTTP fetcher (SSRF protection, multi-UA) |
|
|
48
|
-
| `seo_parse.py` | HTML parser (meta, schema, links, word count) |
|
|
49
|
-
| `seo_crawl.py` | Recursive mini-crawler with sitemap discovery |
|
|
50
|
-
| `seo_screenshot.py` | Playwright viewport screenshots + above-fold analysis |
|
|
51
|
-
|
|
52
|
-
## Scoring System
|
|
53
|
-
|
|
54
|
-
| Category | Weight |
|
|
55
|
-
|----------|--------|
|
|
56
|
-
| Technical SEO | 20% |
|
|
57
|
-
| Content & E-E-A-T | 22% |
|
|
58
|
-
| On-Page SEO | 18% |
|
|
59
|
-
| Schema | 10% |
|
|
60
|
-
| Performance (CWV) | 12% |
|
|
61
|
-
| AI Readiness (GEO) | 12% |
|
|
62
|
-
| Images | 6% |
|
|
63
|
-
|
|
64
|
-
## License
|
|
65
|
-
|
|
66
|
-
MIT — By Laurent Rochetta
|