@atlashub/smartstack-cli 4.18.0 → 4.20.0

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.
Files changed (164) hide show
  1. package/package.json +1 -1
  2. package/templates/agents/ba-reader.md +86 -80
  3. package/templates/agents/ba-writer.md +318 -415
  4. package/templates/agents/docs-context-reader.md +3 -3
  5. package/templates/mcp-scaffolding/frontend/nav-routes.ts.hbs +133 -0
  6. package/templates/mcp-scaffolding/frontend/routes.tsx.hbs +126 -0
  7. package/templates/skills/apex/SKILL.md +29 -16
  8. package/templates/skills/apex/_shared.md +62 -9
  9. package/templates/skills/apex/references/analysis-methods.md +8 -6
  10. package/templates/skills/apex/references/challenge-questions.md +5 -5
  11. package/templates/skills/apex/references/core-seed-data.md +68 -45
  12. package/templates/skills/apex/references/frontend-route-wiring-app-tsx.md +26 -21
  13. package/templates/skills/apex/references/parallel-execution.md +156 -0
  14. package/templates/skills/apex/references/person-extension-pattern.md +12 -12
  15. package/templates/skills/apex/references/post-checks.md +1748 -1726
  16. package/templates/skills/apex/references/smartstack-api.md +63 -57
  17. package/templates/skills/apex/references/smartstack-frontend-compliance.md +594 -0
  18. package/templates/skills/apex/references/smartstack-frontend.md +1246 -1842
  19. package/templates/skills/apex/references/smartstack-layers.md +98 -145
  20. package/templates/skills/apex/steps/step-00-init.md +30 -6
  21. package/templates/skills/apex/steps/step-01-analyze.md +27 -23
  22. package/templates/skills/apex/steps/step-02-plan.md +12 -12
  23. package/templates/skills/apex/steps/step-03-execute.md +198 -143
  24. package/templates/skills/apex/steps/step-04-examine.md +24 -93
  25. package/templates/skills/apex/steps/step-05-deep-review.md +16 -16
  26. package/templates/skills/apex/steps/step-06-resolve.md +9 -9
  27. package/templates/skills/apex/steps/step-07-tests.md +3 -1
  28. package/templates/skills/apex/steps/step-08-run-tests.md +1 -1
  29. package/templates/skills/business-analyse/SKILL.md +182 -301
  30. package/templates/skills/business-analyse/_shared.md +119 -336
  31. package/templates/skills/business-analyse/html/ba-interactive.html +706 -85
  32. package/templates/skills/business-analyse/html/build-html.js +41 -3
  33. package/templates/skills/business-analyse/html/src/partials/cadrage-context.html +34 -0
  34. package/templates/skills/business-analyse/html/src/partials/cadrage-risks.html +48 -0
  35. package/templates/skills/business-analyse/html/src/partials/cadrage-scope.html +49 -0
  36. package/templates/skills/business-analyse/html/src/partials/cadrage-stakeholders.html +55 -0
  37. package/templates/skills/business-analyse/html/src/partials/cadrage-success.html +34 -0
  38. package/templates/skills/business-analyse/html/src/partials/consol-datamodel.html +8 -0
  39. package/templates/skills/business-analyse/html/src/partials/consol-flows.html +29 -0
  40. package/templates/skills/business-analyse/html/src/partials/consol-interactions.html +8 -0
  41. package/templates/skills/business-analyse/html/src/partials/consol-permissions.html +8 -0
  42. package/templates/skills/business-analyse/html/src/partials/decomp-dependencies.html +38 -0
  43. package/templates/skills/business-analyse/html/src/partials/decomp-modules.html +51 -0
  44. package/templates/skills/business-analyse/html/src/partials/handoff-summary.html +24 -0
  45. package/templates/skills/business-analyse/html/src/partials/module-spec-container.html +4 -0
  46. package/templates/skills/business-analyse/html/src/scripts/01-data-init.js +17 -1
  47. package/templates/skills/business-analyse/html/src/scripts/02-navigation.js +32 -6
  48. package/templates/skills/business-analyse/html/src/scripts/05-render-specs.js +100 -63
  49. package/templates/skills/business-analyse/html/src/scripts/06-render-mockups.js +372 -0
  50. package/templates/skills/business-analyse/html/src/scripts/07-render-handoff.js +1 -1
  51. package/templates/skills/business-analyse/html/src/scripts/10-comments.js +41 -13
  52. package/templates/skills/business-analyse/html/src/styles/09-mockups-html.css +136 -0
  53. package/templates/skills/business-analyse/html/src/template.html +1 -1
  54. package/templates/skills/business-analyse/patterns/suggestion-catalog.md +7 -5
  55. package/templates/skills/business-analyse/questionnaire/01-context.md +11 -157
  56. package/templates/skills/business-analyse/questionnaire/02-stakeholders-scope.md +101 -0
  57. package/templates/skills/business-analyse/questionnaire/03-data-ui.md +92 -0
  58. package/templates/skills/business-analyse/questionnaire/04-risks-metrics.md +6 -0
  59. package/templates/skills/business-analyse/questionnaire/05-cross-module.md +69 -0
  60. package/templates/skills/business-analyse/questionnaire.md +22 -280
  61. package/templates/skills/business-analyse/react/application-viewer.md +2 -2
  62. package/templates/skills/business-analyse/react/components.md +4 -4
  63. package/templates/skills/business-analyse/react/i18n-template.md +1 -1
  64. package/templates/skills/business-analyse/react/schema.md +14 -14
  65. package/templates/skills/business-analyse/references/acceptance-criteria.md +21 -21
  66. package/templates/skills/business-analyse/references/analysis-semantic-checks.md +3 -3
  67. package/templates/skills/business-analyse/references/compilation-structure-cards.md +1 -1
  68. package/templates/skills/business-analyse/references/consolidation-structural-checks.md +5 -5
  69. package/templates/skills/business-analyse/references/deploy-data-build.md +12 -11
  70. package/templates/skills/business-analyse/references/deploy-modes.md +10 -10
  71. package/templates/skills/business-analyse/references/detection-strategies.md +6 -6
  72. package/templates/skills/business-analyse/references/html-data-mapping.md +15 -15
  73. package/templates/skills/business-analyse/references/naming-conventions.md +4 -4
  74. package/templates/skills/business-analyse/references/review-data-mapping.md +29 -29
  75. package/templates/skills/business-analyse/references/robustness-checks.md +36 -36
  76. package/templates/skills/business-analyse/references/spec-auto-inference.md +2 -2
  77. package/templates/skills/business-analyse/references/ui-dashboard-spec.md +1 -1
  78. package/templates/skills/business-analyse/references/ui-resource-cards.md +1 -1
  79. package/templates/skills/business-analyse/references/validation-checklist.md +3 -3
  80. package/templates/skills/business-analyse/references/wireframe-svg-style-guide.md +2 -2
  81. package/templates/skills/business-analyse/schemas/application-schema.json +8 -8
  82. package/templates/skills/business-analyse/schemas/feature-schema.json +3 -3
  83. package/templates/skills/business-analyse/schemas/index-schema.json +47 -0
  84. package/templates/skills/business-analyse/schemas/project-schema.json +6 -6
  85. package/templates/skills/business-analyse/schemas/sections/analysis-schema.json +1 -1
  86. package/templates/skills/business-analyse/schemas/sections/handoff-schema.json +5 -3
  87. package/templates/skills/business-analyse/schemas/sections/metadata-schema.json +4 -4
  88. package/templates/skills/business-analyse/schemas/sections/specification-schema.json +1 -1
  89. package/templates/skills/business-analyse/schemas/shared/common-defs.json +4 -4
  90. package/templates/skills/business-analyse/steps/step-00-init.md +68 -77
  91. package/templates/skills/business-analyse/steps/step-01-cadrage.md +50 -216
  92. package/templates/skills/business-analyse/steps/step-02-structure.md +175 -0
  93. package/templates/skills/business-analyse/steps/step-03-specify.md +198 -0
  94. package/templates/skills/business-analyse/steps/step-04-consolidate.md +478 -0
  95. package/templates/skills/business-analyse/steps/step-05-deploy.md +220 -0
  96. package/templates/skills/business-analyse/steps/step-06-review.md +51 -69
  97. package/templates/skills/business-analyse/templates/tpl-frd.md +1 -1
  98. package/templates/skills/business-analyse/templates/tpl-handoff.md +20 -17
  99. package/templates/skills/business-analyse/templates/tpl-launch-displays.md +2 -2
  100. package/templates/skills/business-analyse/templates-react.md +2 -2
  101. package/templates/skills/derive-prd/SKILL.md +92 -0
  102. package/templates/skills/derive-prd/references/acceptance-criteria.md +169 -0
  103. package/templates/skills/derive-prd/references/entity-domain-mapping.md +115 -0
  104. package/templates/skills/{business-analyse → derive-prd}/references/handoff-file-templates.md +131 -120
  105. package/templates/skills/{business-analyse → derive-prd}/references/handoff-mappings.md +95 -95
  106. package/templates/skills/{business-analyse → derive-prd}/references/handoff-seeddata-generation.md +312 -312
  107. package/templates/skills/{business-analyse → derive-prd}/references/prd-generation.md +262 -263
  108. package/templates/skills/derive-prd/references/readiness-scoring.md +104 -0
  109. package/templates/skills/derive-prd/schemas/handoff-schema.json +95 -0
  110. package/templates/skills/derive-prd/steps/step-00-validate.md +130 -0
  111. package/templates/skills/derive-prd/steps/step-01-transform.md +206 -0
  112. package/templates/skills/derive-prd/steps/step-02-export.md +181 -0
  113. package/templates/skills/{business-analyse → derive-prd}/templates/tpl-progress.md +172 -172
  114. package/templates/skills/documentation/SKILL.md +7 -0
  115. package/templates/skills/ralph-loop/SKILL.md +2 -1
  116. package/templates/skills/ralph-loop/references/init-resume-recovery.md +1 -1
  117. package/templates/skills/ralph-loop/steps/step-01-task.md +2 -2
  118. package/templates/skills/apex/references/agent-teams-protocol.md +0 -203
  119. package/templates/skills/business-analyse/_architecture.md +0 -124
  120. package/templates/skills/business-analyse/_elicitation.md +0 -206
  121. package/templates/skills/business-analyse/_module-loop.md +0 -115
  122. package/templates/skills/business-analyse/_rules.md +0 -142
  123. package/templates/skills/business-analyse/_suggestions.md +0 -34
  124. package/templates/skills/business-analyse/questionnaire/00-application.md +0 -160
  125. package/templates/skills/business-analyse/questionnaire/00b-project.md +0 -85
  126. package/templates/skills/business-analyse/questionnaire/02-stakeholders.md +0 -189
  127. package/templates/skills/business-analyse/questionnaire/03-scope.md +0 -164
  128. package/templates/skills/business-analyse/questionnaire/04-data.md +0 -88
  129. package/templates/skills/business-analyse/questionnaire/05-integrations.md +0 -58
  130. package/templates/skills/business-analyse/questionnaire/06-security.md +0 -68
  131. package/templates/skills/business-analyse/questionnaire/07-ui.md +0 -76
  132. package/templates/skills/business-analyse/questionnaire/08-performance.md +0 -42
  133. package/templates/skills/business-analyse/questionnaire/09-constraints.md +0 -45
  134. package/templates/skills/business-analyse/questionnaire/10-documentation.md +0 -58
  135. package/templates/skills/business-analyse/questionnaire/11-data-lifecycle.md +0 -59
  136. package/templates/skills/business-analyse/questionnaire/12-migration.md +0 -58
  137. package/templates/skills/business-analyse/questionnaire/13-cross-module.md +0 -69
  138. package/templates/skills/business-analyse/questionnaire/14-risk-assumptions.md +0 -135
  139. package/templates/skills/business-analyse/questionnaire/15-success-metrics.md +0 -136
  140. package/templates/skills/business-analyse/references/agent-module-prompt.md +0 -366
  141. package/templates/skills/business-analyse/references/agent-pooling-best-practices.md +0 -557
  142. package/templates/skills/business-analyse/references/cache-warming-strategy.md +0 -566
  143. package/templates/skills/business-analyse/references/cadrage-challenge-patterns.md +0 -41
  144. package/templates/skills/business-analyse/references/cadrage-coverage-matrix.md +0 -74
  145. package/templates/skills/business-analyse/references/cadrage-pre-analysis.md +0 -115
  146. package/templates/skills/business-analyse/references/cadrage-shared-modules.md +0 -68
  147. package/templates/skills/business-analyse/references/cadrage-structure-cards.md +0 -85
  148. package/templates/skills/business-analyse/references/team-orchestration.md +0 -1093
  149. package/templates/skills/business-analyse/references/validate-incremental-html.md +0 -121
  150. package/templates/skills/business-analyse/steps/step-01b-applications.md +0 -419
  151. package/templates/skills/business-analyse/steps/step-02-decomposition.md +0 -387
  152. package/templates/skills/business-analyse/steps/step-03a-data.md +0 -16
  153. package/templates/skills/business-analyse/steps/step-03a1-setup.md +0 -486
  154. package/templates/skills/business-analyse/steps/step-03a2-analysis.md +0 -300
  155. package/templates/skills/business-analyse/steps/step-03b-ui.md +0 -405
  156. package/templates/skills/business-analyse/steps/step-03c-compile.md +0 -516
  157. package/templates/skills/business-analyse/steps/step-03d-validate.md +0 -691
  158. package/templates/skills/business-analyse/steps/step-04-consolidation.md +0 -17
  159. package/templates/skills/business-analyse/steps/step-04a-collect.md +0 -415
  160. package/templates/skills/business-analyse/steps/step-04b-analyze.md +0 -163
  161. package/templates/skills/business-analyse/steps/step-04c-decide.md +0 -186
  162. package/templates/skills/business-analyse/steps/step-05a-handoff.md +0 -937
  163. package/templates/skills/business-analyse/steps/step-05b-deploy.md +0 -522
  164. package/templates/skills/business-analyse/steps/step-05c-ralph-readiness.md +0 -703
@@ -4,25 +4,29 @@
4
4
  * Build script for ba-interactive.html
5
5
  *
6
6
  * Assembles the HTML template from split source files:
7
- * - src/template.html (shell with placeholders)
7
+ * - src/template.html (shell with PARTIAL placeholders)
8
+ * - src/partials/*.html (section content files)
8
9
  * - src/styles/*.css (concatenated in alphabetical order)
9
10
  * - src/scripts/*.js (concatenated in alphabetical order)
10
11
  *
11
12
  * Output: ba-interactive.html (single file, compatible with file:// protocol)
12
13
  *
13
- * Preserves template placeholders: {{FEATURE_DATA}}, {{EMBEDDED_ARTIFACTS}}, {{APPLICATION_NAME}}, {{APPLICATION_ID}}
14
+ * Preserves template placeholders: {{FEATURE_DATA}}, {{EMBEDDED_ARTIFACTS}}, {{PROJECT_NAME}}
15
+ * Backward compat: {{APPLICATION_NAME}} and {{APPLICATION_ID}} are also preserved if present
14
16
  */
15
17
 
16
18
  const fs = require('fs');
17
19
  const path = require('path');
18
20
 
19
21
  const SRC_DIR = path.join(__dirname, 'src');
22
+ const PARTIALS_DIR = path.join(SRC_DIR, 'partials');
20
23
  const STYLES_DIR = path.join(SRC_DIR, 'styles');
21
24
  const SCRIPTS_DIR = path.join(SRC_DIR, 'scripts');
22
25
  const TEMPLATE_FILE = path.join(SRC_DIR, 'template.html');
23
26
  const OUTPUT_FILE = path.join(__dirname, 'ba-interactive.html');
24
27
 
25
28
  function readSortedFiles(dir, extension) {
29
+ if (!fs.existsSync(dir)) return [];
26
30
  const files = fs.readdirSync(dir)
27
31
  .filter(f => f.endsWith(extension))
28
32
  .sort();
@@ -33,6 +37,29 @@ function readSortedFiles(dir, extension) {
33
37
  });
34
38
  }
35
39
 
40
+ function resolvePartials(template) {
41
+ const partialRegex = /<!-- PARTIAL:(\S+) -->/g;
42
+ let resolved = template;
43
+ let match;
44
+ const matches = [];
45
+
46
+ while ((match = partialRegex.exec(template)) !== null) {
47
+ matches.push({ placeholder: match[0], name: match[1] });
48
+ }
49
+
50
+ for (const m of matches) {
51
+ const partialFile = path.join(PARTIALS_DIR, m.name + '.html');
52
+ if (fs.existsSync(partialFile)) {
53
+ const partialContent = fs.readFileSync(partialFile, 'utf8');
54
+ resolved = resolved.replace(m.placeholder, partialContent);
55
+ } else {
56
+ console.warn(`[build-html] WARNING: Partial not found: ${m.name}.html`);
57
+ }
58
+ }
59
+
60
+ return resolved;
61
+ }
62
+
36
63
  function build() {
37
64
  console.log('[build-html] Starting build...');
38
65
 
@@ -43,6 +70,13 @@ function build() {
43
70
  }
44
71
  let template = fs.readFileSync(TEMPLATE_FILE, 'utf8');
45
72
 
73
+ // Resolve partials
74
+ if (fs.existsSync(PARTIALS_DIR)) {
75
+ const partialFiles = fs.readdirSync(PARTIALS_DIR).filter(f => f.endsWith('.html'));
76
+ console.log(`[build-html] Partials: ${partialFiles.length} files`);
77
+ template = resolvePartials(template);
78
+ }
79
+
46
80
  // Read and concatenate CSS files
47
81
  const cssFiles = readSortedFiles(STYLES_DIR, '.css');
48
82
  console.log(`[build-html] CSS files: ${cssFiles.map(f => f.name).join(', ')}`);
@@ -58,8 +92,12 @@ function build() {
58
92
  template = template.replace('<!-- JS_PLACEHOLDER -->', js);
59
93
 
60
94
  // Verify placeholders are preserved
61
- const requiredPlaceholders = ['{{FEATURE_DATA}}', '{{EMBEDDED_ARTIFACTS}}', '{{APPLICATION_NAME}}'];
95
+ const requiredPlaceholders = ['{{FEATURE_DATA}}', '{{EMBEDDED_ARTIFACTS}}'];
96
+ // Accept either {{PROJECT_NAME}} or {{APPLICATION_NAME}}
97
+ const hasProjectName = template.includes('{{PROJECT_NAME}}') || template.includes('{{APPLICATION_NAME}}');
62
98
  const missing = requiredPlaceholders.filter(p => !template.includes(p));
99
+ if (!hasProjectName) missing.push('{{PROJECT_NAME}} or {{APPLICATION_NAME}}');
100
+
63
101
  if (missing.length > 0) {
64
102
  console.error('[build-html] ERROR: Missing placeholders:', missing.join(', '));
65
103
  process.exit(1);
@@ -0,0 +1,34 @@
1
+ <!-- SECTION: Contexte (merged: problem + current + vision) -->
2
+ <div class="section" id="cadrage-context">
3
+ <h2 class="section-title">Contexte du projet</h2>
4
+ <p class="section-subtitle">Vue synthetique du besoin : probleme, situation actuelle et objectif vise.</p>
5
+
6
+ <div style="display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;">
7
+ <div class="card" style="border-left:3px solid #f87171;">
8
+ <div class="card-label" style="color:#f87171;">Probleme identifie</div>
9
+ <div class="editable" contenteditable="true" data-field="context.problem" data-placeholder="Quel probleme ce projet doit-il resoudre ?"></div>
10
+ <div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
11
+ <strong>Declencheur :</strong>
12
+ <div class="editable" contenteditable="true" data-field="context.trigger" data-placeholder="Evenement declencheur" style="display:inline;"></div>
13
+ </div>
14
+ </div>
15
+
16
+ <div class="card" style="border-left:3px solid #facc15;">
17
+ <div class="card-label" style="color:#facc15;">Aujourd'hui</div>
18
+ <div class="editable" contenteditable="true" data-field="context.currentSituation" data-placeholder="Comment les choses fonctionnent actuellement ?"></div>
19
+ <div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
20
+ <strong>Points douleur :</strong>
21
+ <div class="editable" contenteditable="true" data-field="context.painPoints" data-placeholder="Problemes recurrents" style="display:inline;"></div>
22
+ </div>
23
+ </div>
24
+
25
+ <div class="card" style="border-left:3px solid #4ade80;">
26
+ <div class="card-label" style="color:#4ade80;">Objectif</div>
27
+ <div class="editable" contenteditable="true" data-field="context.desiredSituation" data-placeholder="Que doit permettre le systeme cible ?"></div>
28
+ <div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
29
+ <strong>Criteres :</strong>
30
+ <div class="editable" contenteditable="true" data-field="context.acceptanceCriteria" data-placeholder="Criteres de succes" style="display:inline;"></div>
31
+ </div>
32
+ </div>
33
+ </div>
34
+ </div>
@@ -0,0 +1,48 @@
1
+ <!-- SECTION: Risques et hypotheses -->
2
+ <div class="section" id="cadrage-risks" style="display:none;" data-vibe-hide>
3
+ <h2 class="section-title">Risques et hypotheses</h2>
4
+ <p class="section-subtitle">Ce qui pourrait mal tourner et les certitudes non verifiees.</p>
5
+
6
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">Risques identifies</h3>
7
+ <div id="risksList"></div>
8
+ <button class="add-btn" onclick="toggleForm('addRiskForm')">+ Ajouter un risque</button>
9
+
10
+ <div class="inline-form" id="addRiskForm">
11
+ <div class="inline-form-title">Nouveau risque</div>
12
+ <div class="form-group">
13
+ <label class="form-label">Description du risque</label>
14
+ <input type="text" class="form-input" id="risk-desc" placeholder="Qu'est-ce qui pourrait mal tourner ?">
15
+ </div>
16
+ <div class="form-row">
17
+ <div class="form-group">
18
+ <label class="form-label">Probabilite</label>
19
+ <select class="form-select" id="risk-probability">
20
+ <option value="high">Forte</option>
21
+ <option value="medium">Moyenne</option>
22
+ <option value="low">Faible</option>
23
+ </select>
24
+ </div>
25
+ <div class="form-group">
26
+ <label class="form-label">Impact</label>
27
+ <select class="form-select" id="risk-impact">
28
+ <option value="high">Grave</option>
29
+ <option value="medium">Moyen</option>
30
+ <option value="low">Faible</option>
31
+ </select>
32
+ </div>
33
+ </div>
34
+ <div class="form-group">
35
+ <label class="form-label">Mesure de prevention ou de reduction</label>
36
+ <textarea class="form-textarea" id="risk-mitigation" placeholder="Comment prevenir ou reduire ce risque ?"></textarea>
37
+ </div>
38
+ <div class="form-actions">
39
+ <button class="btn" onclick="toggleForm('addRiskForm')">Annuler</button>
40
+ <button class="btn btn-primary" onclick="addRisk()">Ajouter ce risque</button>
41
+ </div>
42
+ </div>
43
+
44
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Hypotheses a verifier</h3>
45
+ <div class="card">
46
+ <div class="editable" contenteditable="true" data-field="risks.assumptions" data-placeholder="Quelles hypotheses faites-vous sur ce projet sans les avoir verifiees ? (une par ligne)"></div>
47
+ </div>
48
+ </div>
@@ -0,0 +1,49 @@
1
+ <!-- SECTION: Perimetre fonctionnel -->
2
+ <div class="section" id="cadrage-scope" style="display:none;">
3
+ <h2 class="section-title">Perimetre fonctionnel</h2>
4
+ <p class="section-subtitle">Ce que le systeme doit faire et ne pas faire, par ordre de priorite.</p>
5
+
6
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">
7
+ <span style="color: #f87171;">&#9632;</span> Fonctionnalites indispensables
8
+ </h3>
9
+ <div id="scopeVital" class="uc-list"></div>
10
+ <button class="add-btn" onclick="toggleForm('addScopeForm-vital')">+ Ajouter une fonctionnalite indispensable</button>
11
+ <div class="inline-form" id="addScopeForm-vital">
12
+ <div class="form-group"><label class="form-label">Nom de la fonctionnalite</label><input type="text" class="form-input" id="scope-name-vital" placeholder="Ex: Gestion des commandes"></div>
13
+ <div class="form-group"><label class="form-label">Description (optionnel)</label><input type="text" class="form-input" id="scope-desc-vital" placeholder="Courte description"></div>
14
+ <div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-vital')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('vital')">Ajouter</button></div>
15
+ </div>
16
+
17
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
18
+ <span style="color: #facc15;">&#9632;</span> Fonctionnalites importantes
19
+ </h3>
20
+ <div id="scopeImportant" class="uc-list"></div>
21
+ <button class="add-btn" onclick="toggleForm('addScopeForm-important')">+ Ajouter une fonctionnalite importante</button>
22
+ <div class="inline-form" id="addScopeForm-important">
23
+ <div class="form-group"><label class="form-label">Nom de la fonctionnalite</label><input type="text" class="form-input" id="scope-name-important" placeholder="Ex: Export PDF"></div>
24
+ <div class="form-group"><label class="form-label">Description (optionnel)</label><input type="text" class="form-input" id="scope-desc-important" placeholder="Courte description"></div>
25
+ <div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-important')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('important')">Ajouter</button></div>
26
+ </div>
27
+
28
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
29
+ <span style="color: #4ade80;">&#9632;</span> Fonctionnalites optionnelles
30
+ </h3>
31
+ <div id="scopeOptional" class="uc-list"></div>
32
+ <button class="add-btn" onclick="toggleForm('addScopeForm-optional')">+ Ajouter une fonctionnalite optionnelle</button>
33
+ <div class="inline-form" id="addScopeForm-optional">
34
+ <div class="form-group"><label class="form-label">Nom de la fonctionnalite</label><input type="text" class="form-input" id="scope-name-optional" placeholder="Ex: Calendrier partage"></div>
35
+ <div class="form-group"><label class="form-label">Description (optionnel)</label><input type="text" class="form-input" id="scope-desc-optional" placeholder="Courte description"></div>
36
+ <div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-optional')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('optional')">Ajouter</button></div>
37
+ </div>
38
+
39
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
40
+ <span style="color: #94a3b8;">&#9632;</span> Hors perimetre
41
+ </h3>
42
+ <div id="scopeExcluded" class="uc-list"></div>
43
+ <button class="add-btn" onclick="toggleForm('addScopeForm-excluded')">+ Ajouter une exclusion</button>
44
+ <div class="inline-form" id="addScopeForm-excluded">
45
+ <div class="form-group"><label class="form-label">Element hors perimetre</label><input type="text" class="form-input" id="scope-name-excluded" placeholder="Ex: Gestion de la paie"></div>
46
+ <div class="form-group"><label class="form-label">Raison (optionnel)</label><input type="text" class="form-input" id="scope-desc-excluded" placeholder="Pourquoi hors perimetre"></div>
47
+ <div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-excluded')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('excluded')">Ajouter</button></div>
48
+ </div>
49
+ </div>
@@ -0,0 +1,55 @@
1
+ <!-- SECTION: Parties prenantes -->
2
+ <div class="section" id="cadrage-stakeholders" style="display:none;">
3
+ <h2 class="section-title">Parties prenantes</h2>
4
+ <p class="section-subtitle">Toutes les personnes concernees par ce projet et leurs besoins.</p>
5
+
6
+ <div class="stakeholder-grid" id="stakeholderGrid">
7
+ <!-- Populated dynamically -->
8
+ </div>
9
+
10
+ <button class="add-btn" onclick="toggleForm('addStakeholderForm')">+ Ajouter un profil utilisateur</button>
11
+
12
+ <div class="inline-form" id="addStakeholderForm">
13
+ <div class="inline-form-title">Nouveau profil utilisateur</div>
14
+ <div class="form-group">
15
+ <label class="form-label">Titre du profil (exemple : Responsable de production)</label>
16
+ <input type="text" class="form-input" id="sh-role" placeholder="Titre ou description du profil">
17
+ </div>
18
+ <div class="form-group">
19
+ <label class="form-label">Fonction dans l'entreprise</label>
20
+ <input type="text" class="form-input" id="sh-function" placeholder="Ce qu'il fait dans l'organisation">
21
+ </div>
22
+ <div class="form-group">
23
+ <label class="form-label">Taches principales (une par ligne)</label>
24
+ <textarea class="form-textarea" id="sh-tasks" placeholder="Tache 1&#10;Tache 2&#10;Tache 3"></textarea>
25
+ </div>
26
+ <div class="form-row">
27
+ <div class="form-group">
28
+ <label class="form-label">Frequence d'utilisation</label>
29
+ <select class="form-select" id="sh-frequency">
30
+ <option value="daily">Quotidienne</option>
31
+ <option value="weekly">Hebdomadaire</option>
32
+ <option value="monthly">Mensuelle</option>
33
+ <option value="occasional">Occasionnelle</option>
34
+ </select>
35
+ </div>
36
+ <div class="form-group">
37
+ <label class="form-label">Niveau d'acces</label>
38
+ <select class="form-select" id="sh-access">
39
+ <option value="admin">Administration complete</option>
40
+ <option value="manager">Supervision et validation</option>
41
+ <option value="contributor">Saisie et modification</option>
42
+ <option value="viewer">Consultation seule</option>
43
+ </select>
44
+ </div>
45
+ </div>
46
+ <div class="form-group">
47
+ <label class="form-label">Frustrations actuelles</label>
48
+ <textarea class="form-textarea" id="sh-frustrations" placeholder="Quelles sont les 2-3 plus grandes frustrations de ce profil avec la facon de travailler actuelle ?"></textarea>
49
+ </div>
50
+ <div class="form-actions">
51
+ <button class="btn" onclick="toggleForm('addStakeholderForm')">Annuler</button>
52
+ <button class="btn btn-primary" onclick="addStakeholder()">Ajouter ce profil</button>
53
+ </div>
54
+ </div>
55
+ </div>
@@ -0,0 +1,34 @@
1
+ <!-- SECTION: Criteres de reussite -->
2
+ <div class="section" id="cadrage-success" style="display:none;">
3
+ <h2 class="section-title">Criteres de reussite</h2>
4
+ <p class="section-subtitle">Comment mesurer objectivement que le projet est un succes.</p>
5
+
6
+ <div class="card">
7
+ <div class="card-label">Definition du succes</div>
8
+ <div class="editable" contenteditable="true" data-field="success.definition" data-placeholder="Comment saurez-vous que le projet est un succes ? Quel changement concret observerez-vous ?"></div>
9
+ </div>
10
+
11
+ <div class="card" data-vibe-hide>
12
+ <div class="card-label">Objectifs mesurables</div>
13
+ <div class="editable" contenteditable="true" data-field="success.metrics" data-placeholder="Quels chiffres presenteriez-vous a votre direction pour prouver le succes ? (temps, erreurs, satisfaction...)"></div>
14
+ </div>
15
+
16
+ <div class="card" data-vibe-hide>
17
+ <div class="card-label">Delai d'evaluation</div>
18
+ <div class="editable" contenteditable="true" data-field="success.timeline" data-placeholder="Au bout de combien de temps pourrez-vous juger si ca fonctionne ? 1 semaine ? 1 mois ? 3 mois ?"></div>
19
+ </div>
20
+
21
+ <div class="card" data-vibe-hide>
22
+ <div class="card-label">Conditions minimales de mise en service</div>
23
+ <div class="editable" contenteditable="true" data-field="success.minimumConditions" data-placeholder="Quelles conditions minimales pour mettre le systeme en service ? (fonctionnalites presentes, donnees migrees, formation faite...)"></div>
24
+ </div>
25
+
26
+ <h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Criteres d'acceptation</h3>
27
+ <p style="font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem;">Criteres concrets et mesurables pour valider le succes du projet.</p>
28
+ <div id="criteriaList" class="uc-list"></div>
29
+ <button class="add-btn" onclick="toggleForm('addCriterionForm')">+ Ajouter un critere d'acceptation</button>
30
+ <div class="inline-form" id="addCriterionForm">
31
+ <div class="form-group"><label class="form-label">Critere (mesurable)</label><input type="text" class="form-input" id="criterion-text" placeholder="Ex: 80% des employes saisissent leurs heures chaque semaine"></div>
32
+ <div class="form-actions"><button class="btn" onclick="toggleForm('addCriterionForm')">Annuler</button><button class="btn btn-primary" onclick="addCriterion()">Ajouter</button></div>
33
+ </div>
34
+ </div>
@@ -0,0 +1,8 @@
1
+ <!-- SECTION: Modele de donnees -->
2
+ <div class="section" id="consol-datamodel" style="display:none;">
3
+ <h2 class="section-title">Modele de donnees</h2>
4
+ <p class="section-subtitle">Vue d'ensemble de toutes les entites metier, leurs attributs et leurs relations entre domaines.</p>
5
+ <div id="dataModelContainer">
6
+ <p style="color:var(--text-muted);text-align:center;padding:2rem;">Le modele de donnees sera genere a partir des specifications de chaque domaine.</p>
7
+ </div>
8
+ </div>
@@ -0,0 +1,29 @@
1
+ <!-- SECTION: Parcours bout en bout -->
2
+ <div class="section" id="consol-flows" style="display:none;">
3
+ <h2 class="section-title">Parcours bout en bout</h2>
4
+ <p class="section-subtitle">Les processus metier qui traversent plusieurs domaines, de bout en bout.</p>
5
+
6
+ <div id="e2eFlowsList"></div>
7
+
8
+ <button class="add-btn" onclick="toggleForm('addFlowForm')">+ Ajouter un parcours</button>
9
+
10
+ <div class="inline-form" id="addFlowForm">
11
+ <div class="inline-form-title">Nouveau parcours bout en bout</div>
12
+ <div class="form-group">
13
+ <label class="form-label">Nom du parcours (exemple : De la commande a la facture)</label>
14
+ <input type="text" class="form-input" id="flow-name" placeholder="Nom descriptif du parcours">
15
+ </div>
16
+ <div class="form-group">
17
+ <label class="form-label">Etapes du parcours (une par ligne : Domaine - Action)</label>
18
+ <textarea class="form-textarea" id="flow-steps" placeholder="Clients - Le client existe dans le systeme&#10;Commandes - Creer la commande&#10;Commandes - Valider la commande&#10;Factures - Generer la facture"></textarea>
19
+ </div>
20
+ <div class="form-group">
21
+ <label class="form-label">Qui intervient dans ce parcours ?</label>
22
+ <input type="text" class="form-input" id="flow-actors" placeholder="Exemple : Contributeur (creation), Responsable (validation)">
23
+ </div>
24
+ <div class="form-actions">
25
+ <button class="btn" onclick="toggleForm('addFlowForm')">Annuler</button>
26
+ <button class="btn btn-primary" onclick="addE2EFlow()">Ajouter ce parcours</button>
27
+ </div>
28
+ </div>
29
+ </div>
@@ -0,0 +1,8 @@
1
+ <!-- SECTION: Interactions cross-module -->
2
+ <div class="section" id="consol-interactions" style="display:none;">
3
+ <h2 class="section-title">Interactions entre domaines</h2>
4
+ <p class="section-subtitle">Vue d'ensemble de la facon dont les domaines communiquent et partagent des donnees.</p>
5
+ <div id="consolInteractions">
6
+ <p style="color:var(--text-muted);text-align:center;padding:2rem;">Les interactions seront calculees automatiquement a partir des dependances et des donnees partagees entre domaines.</p>
7
+ </div>
8
+ </div>
@@ -0,0 +1,8 @@
1
+ <!-- SECTION: Coherence des acces -->
2
+ <div class="section" id="consol-permissions" style="display:none;">
3
+ <h2 class="section-title">Coherence des droits d'acces</h2>
4
+ <p class="section-subtitle">Verification que les profils utilisateurs ont des droits coherents dans tous les domaines.</p>
5
+ <div id="consolPermissions">
6
+ <p style="color:var(--text-muted);text-align:center;padding:2rem;">La coherence sera verifiee quand les permissions de chaque domaine seront definies.</p>
7
+ </div>
8
+ </div>
@@ -0,0 +1,38 @@
1
+ <!-- SECTION: Dependances -->
2
+ <div class="section" id="decomp-dependencies" style="display:none;">
3
+ <h2 class="section-title">Dependances entre domaines</h2>
4
+ <p class="section-subtitle">Indiquez quels domaines dependent d'autres domaines. Par exemple, les Commandes dependent des Clients et des Produits.</p>
5
+
6
+ <div id="depGraphContainer">
7
+ <div class="dep-graph" id="depGraph">
8
+ <p style="color:var(--text-muted);text-align:center;padding:2rem;">Ajoutez des domaines fonctionnels pour visualiser les dependances.</p>
9
+ </div>
10
+ </div>
11
+
12
+ <div style="margin-top:1.5rem;">
13
+ <h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ajouter une dependance</h3>
14
+ <div class="form-row">
15
+ <div class="form-group">
16
+ <label class="form-label">Ce domaine...</label>
17
+ <select class="form-select" id="dep-from"></select>
18
+ </div>
19
+ <div class="form-group">
20
+ <label class="form-label">...depend de</label>
21
+ <select class="form-select" id="dep-to"></select>
22
+ </div>
23
+ </div>
24
+ <div class="form-group">
25
+ <label class="form-label">Nature de la dependance</label>
26
+ <input type="text" class="form-input" id="dep-desc" placeholder="Exemple : La commande reference un client existant">
27
+ </div>
28
+ <button class="btn btn-primary" onclick="addDependency()" style="margin-top:0.5rem;">Ajouter cette dependance</button>
29
+ </div>
30
+
31
+ <div id="depList" style="margin-top:1.5rem;"></div>
32
+
33
+ <div style="margin-top:2rem;">
34
+ <h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ordre de traitement propose</h3>
35
+ <p class="section-subtitle">Les domaines sont traites dans l'ordre de leurs dependances : les fondations d'abord, puis les domaines qui en dependent.</p>
36
+ <div id="processingOrder" class="process-flow"></div>
37
+ </div>
38
+ </div>
@@ -0,0 +1,51 @@
1
+ <!-- SECTION: Domaines fonctionnels -->
2
+ <div class="section" id="decomp-modules" style="display:none;">
3
+ <h2 class="section-title">Domaines fonctionnels</h2>
4
+ <p class="section-subtitle">Identifiez les grands domaines de votre application. Chaque domaine regroupe des fonctionnalites coherentes et independantes.</p>
5
+
6
+ <div class="module-grid" id="moduleGrid">
7
+ <!-- Populated dynamically -->
8
+ </div>
9
+
10
+ <button class="add-btn" onclick="toggleForm('addModuleForm')" style="margin-top:1rem;">+ Ajouter un domaine fonctionnel</button>
11
+
12
+ <div class="inline-form" id="addModuleForm">
13
+ <div class="inline-form-title">Nouveau domaine fonctionnel</div>
14
+ <div class="form-group">
15
+ <label class="form-label">Nom du domaine (exemple : Gestion des commandes)</label>
16
+ <input type="text" class="form-input" id="mod-name" placeholder="Nom clair et explicite">
17
+ </div>
18
+ <div class="form-group">
19
+ <label class="form-label">Description en une ou deux phrases</label>
20
+ <textarea class="form-textarea" id="mod-desc" placeholder="A quoi sert ce domaine ? Quel probleme resout-il ?"></textarea>
21
+ </div>
22
+ <div class="form-row">
23
+ <div class="form-group">
24
+ <label class="form-label">Type de domaine</label>
25
+ <select class="form-select" id="mod-type">
26
+ <option value="data-centric">Gestion de donnees (listes, fiches, formulaires)</option>
27
+ <option value="workflow">Processus metier (etapes, validations, approbations)</option>
28
+ <option value="reporting">Tableaux de bord et rapports</option>
29
+ <option value="integration">Integration avec des systemes externes</option>
30
+ <option value="full-module">Domaine complet (donnees + processus + rapports)</option>
31
+ </select>
32
+ </div>
33
+ <div class="form-group">
34
+ <label class="form-label">Priorite</label>
35
+ <select class="form-select" id="mod-priority">
36
+ <option value="must">Indispensable</option>
37
+ <option value="should">Important</option>
38
+ <option value="could">Optionnel</option>
39
+ </select>
40
+ </div>
41
+ </div>
42
+ <div class="form-group">
43
+ <label class="form-label">Principales donnees gerees (une par ligne)</label>
44
+ <textarea class="form-textarea" id="mod-entities" placeholder="Commande&#10;Ligne de commande&#10;Facture"></textarea>
45
+ </div>
46
+ <div class="form-actions">
47
+ <button class="btn" onclick="toggleForm('addModuleForm')">Annuler</button>
48
+ <button class="btn btn-primary" onclick="addModule()">Ajouter ce domaine</button>
49
+ </div>
50
+ </div>
51
+ </div>
@@ -0,0 +1,24 @@
1
+ <div class="section" id="handoff-summary" style="display:none;">
2
+ <h2 class="section-title">Synthese de l'analyse</h2>
3
+ <p class="section-subtitle">Vue d'ensemble de toute l'analyse metier, prete pour le developpement.</p>
4
+
5
+ <div class="stat-grid" id="handoffStats">
6
+ <!-- Populated dynamically -->
7
+ </div>
8
+
9
+ <h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Domaines par ordre de traitement</h3>
10
+ <div id="handoffModuleList"></div>
11
+
12
+ <h3 style="color:var(--text-bright);font-size:1rem;margin:1.5rem 0 0.75rem;">Couverture du besoin initial</h3>
13
+ <div class="card">
14
+ <div class="card-label">Matrice de couverture</div>
15
+ <p style="font-size:0.85rem;color:var(--text-muted);margin-bottom:0.75rem;">Chaque besoin du cadrage est couvert par au moins un domaine et un cas d'utilisation.</p>
16
+ <div id="coverageMatrix"></div>
17
+ </div>
18
+
19
+ <div style="margin-top:2rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;text-align:center;">
20
+ <p style="color:var(--text-bright);font-size:1.1rem;font-weight:600;margin-bottom:0.5rem;">Analyse prete pour l'extraction</p>
21
+ <p style="color:var(--text-muted);font-size:0.85rem;margin-bottom:1rem;">Exportez le fichier JSON pour lancer la generation automatique du systeme.</p>
22
+ <button class="btn btn-primary" onclick="exportJSON()" style="font-size:0.9rem;padding:0.6rem 1.5rem;">Exporter l'analyse complete en JSON</button>
23
+ </div>
24
+ </div>
@@ -0,0 +1,4 @@
1
+ <!-- Container dynamique pour les specs de chaque module -->
2
+ <div id="moduleSpecContainer">
3
+ <!-- Generated dynamically by renderModuleSpec() -->
4
+ </div>
@@ -6,6 +6,9 @@ let data = {{FEATURE_DATA}};
6
6
  const ORIGINAL_DATA = JSON.parse(JSON.stringify(data));
7
7
  const EMBEDDED_ARTIFACTS = {{EMBEDDED_ARTIFACTS}};
8
8
 
9
+ // Initialize applications array (multi-app support)
10
+ data.applications = data.applications || [];
11
+
9
12
  // Initialize optional data structures
10
13
  data.wireframeComments = data.wireframeComments || {};
11
14
  data.specComments = data.specComments || {};
@@ -32,7 +35,7 @@ data.cadrage.context = data.cadrage.context || { problem: '', trigger: '', curre
32
35
  // Initialize comments array
33
36
  data.comments = data.comments || [];
34
37
 
35
- // Defensive mapping: globalScope (feature.json format) -> scope (HTML format)
38
+ // Defensive mapping: globalScope (JSON format) -> scope (HTML format)
36
39
  // Handles cases where FEATURE_DATA contains raw globalScope instead of pre-mapped scope
37
40
  if (!data.cadrage.scope || (!data.cadrage.scope.vital?.length && data.cadrage.globalScope)) {
38
41
  const gs = data.cadrage.globalScope || {};
@@ -45,6 +48,14 @@ if (!data.cadrage.scope || (!data.cadrage.scope.vital?.length && data.cadrage.gl
45
48
  }
46
49
  data.cadrage.scope = data.cadrage.scope || { vital: [], important: [], optional: [], excluded: [] };
47
50
 
51
+ // Backward compat: mustHave/shouldHave/couldHave/wontHave → vital/important/optional/excluded
52
+ if (data.cadrage.scope.mustHave && !data.cadrage.scope.vital?.length) {
53
+ data.cadrage.scope.vital = data.cadrage.scope.mustHave;
54
+ data.cadrage.scope.important = data.cadrage.scope.shouldHave || data.cadrage.scope.important || [];
55
+ data.cadrage.scope.optional = data.cadrage.scope.couldHave || data.cadrage.scope.optional || [];
56
+ data.cadrage.scope.excluded = data.cadrage.scope.wontHave || data.cadrage.scope.excluded || [];
57
+ }
58
+
48
59
  // Defensive init: moduleSpecs (may be missing if LLM didn't follow mapping)
49
60
  data.moduleSpecs = data.moduleSpecs || {};
50
61
  // Ensure ALL modules have a moduleSpecs entry (prevents missing schemas)
@@ -54,6 +65,11 @@ data.moduleSpecs = data.moduleSpecs || {};
54
65
  }
55
66
  // Ensure anticipatedSections array exists
56
67
  m.anticipatedSections = m.anticipatedSections || [];
68
+ m.applicationCode = m.applicationCode || '';
69
+ // Initialize screens array for interface specs
70
+ if (!data.moduleSpecs[m.code].screens) {
71
+ data.moduleSpecs[m.code].screens = [];
72
+ }
57
73
  });
58
74
 
59
75
  // Vibe coding mode: hide non-relevant sections
@@ -51,12 +51,38 @@ function buildNavTree() {
51
51
  const nav = document.getElementById('sidebarNav');
52
52
  if (!nav) return;
53
53
 
54
- nav.innerHTML =
55
- renderNavGroup('cadrage', 'Cadrage', buildCadrageItems()) +
56
- renderNavGroup('modules', 'Modules (' + data.modules.length + ')', buildModuleItems()) +
57
- renderNavGroup('consolidation', 'Consolidation', buildConsolidationItems()) +
58
- renderNavGroup('synthese', 'Synthese', buildSyntheseItems());
54
+ var html = renderNavGroup('cadrage', 'Cadrage', buildCadrageItems());
55
+
56
+ // Multi-app: group modules by application
57
+ if (data.applications && data.applications.length > 1) {
58
+ data.applications.forEach(function(app) {
59
+ var appModules = data.modules.filter(function(m) { return m.applicationCode === app.code; });
60
+ var appModuleItems = '';
61
+ appModules.forEach(function(mod) {
62
+ appModuleItems += renderModuleNavItem(mod);
63
+ });
64
+ // Global views at bottom of each app group
65
+ appModuleItems += renderNavItem('decomp-modules', 'Vue d\'ensemble', data.modules.length);
66
+ html += renderNavGroup('app-' + app.code, app.name || app.code, appModuleItems);
67
+ });
68
+ // Modules without applicationCode
69
+ var orphanModules = data.modules.filter(function(m) { return !m.applicationCode; });
70
+ if (orphanModules.length > 0) {
71
+ var orphanItems = '';
72
+ orphanModules.forEach(function(mod) {
73
+ orphanItems += renderModuleNavItem(mod);
74
+ });
75
+ html += renderNavGroup('modules-other', 'Autres modules (' + orphanModules.length + ')', orphanItems);
76
+ }
77
+ html += renderNavItem('decomp-dependencies', 'Dependances', data.dependencies.length);
78
+ } else {
79
+ html += renderNavGroup('modules', 'Modules (' + data.modules.length + ')', buildModuleItems());
80
+ }
81
+
82
+ html += renderNavGroup('consolidation', 'Consolidation', buildConsolidationItems());
83
+ html += renderNavGroup('synthese', 'Synthese', buildSyntheseItems());
59
84
 
85
+ nav.innerHTML = html;
60
86
  restoreNavState();
61
87
  highlightActiveNavItem();
62
88
  }
@@ -87,7 +113,7 @@ function buildCadrageItems() {
87
113
  return renderNavItem('cadrage-context', 'Contexte') +
88
114
  renderNavItem('cadrage-stakeholders', 'Parties prenantes', data.cadrage.stakeholders.length) +
89
115
  renderNavItem('cadrage-scope', 'Perimetre fonctionnel') +
90
- renderNavItem('cadrage-risks', 'Risques et hypotheses', data.cadrage.risks.length) +
116
+ (isVibeCoding ? '' : renderNavItem('cadrage-risks', 'Risques et hypotheses', data.cadrage.risks.length)) +
91
117
  renderNavItem('cadrage-success', 'Criteres de reussite');
92
118
  }
93
119