@atlashub/smartstack-cli 3.7.0 → 3.9.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.
- package/dist/index.js +365 -2
- package/dist/index.js.map +1 -1
- package/package.json +4 -2
- package/templates/agents/action.md +1 -0
- package/templates/agents/ba-writer.md +33 -0
- package/templates/agents/explore-codebase.md +1 -0
- package/templates/agents/explore-docs.md +1 -0
- package/templates/agents/fix-grammar.md +1 -0
- package/templates/agents/snipper.md +1 -0
- package/templates/skills/admin/SKILL.md +6 -0
- package/templates/skills/ai-prompt/SKILL.md +32 -136
- package/templates/skills/ai-prompt/steps/step-01-implementation.md +122 -0
- package/templates/skills/apex/SKILL.md +120 -0
- package/templates/skills/apex/_shared.md +86 -0
- package/templates/skills/apex/references/agent-teams-protocol.md +164 -0
- package/templates/skills/apex/references/smartstack-layers.md +173 -0
- package/templates/skills/apex/steps/step-00-init.md +156 -0
- package/templates/skills/apex/steps/step-01-analyze.md +169 -0
- package/templates/skills/apex/steps/step-02-plan.md +160 -0
- package/templates/skills/apex/steps/step-03-execute.md +166 -0
- package/templates/skills/apex/steps/step-04-validate.md +138 -0
- package/templates/skills/apex/steps/step-05-examine.md +124 -0
- package/templates/skills/apex/steps/step-06-resolve.md +105 -0
- package/templates/skills/apex/steps/step-07-tests.md +130 -0
- package/templates/skills/apex/steps/step-08-run-tests.md +115 -0
- package/templates/skills/application/SKILL.md +10 -0
- package/templates/skills/application/references/backend-controller-hierarchy.md +58 -0
- package/templates/skills/application/references/backend-entity-seeding.md +72 -0
- package/templates/skills/application/references/backend-verification.md +88 -0
- package/templates/skills/application/references/frontend-verification.md +111 -0
- package/templates/skills/application/references/nav-fallback-procedure.md +200 -0
- package/templates/skills/application/references/provider-template.md +134 -0
- package/templates/skills/application/references/test-frontend.md +73 -0
- package/templates/skills/application/references/test-prerequisites.md +72 -0
- package/templates/skills/application/steps/step-01-navigation.md +7 -198
- package/templates/skills/application/steps/step-03b-provider.md +4 -128
- package/templates/skills/application/steps/step-04-backend.md +20 -350
- package/templates/skills/application/steps/step-05-frontend.md +12 -101
- package/templates/skills/application/steps/step-07-tests.md +12 -132
- package/templates/skills/business-analyse/SKILL.md +11 -2
- package/templates/skills/business-analyse/html/ba-interactive.html +3214 -2246
- package/templates/skills/business-analyse/html/build-html.js +77 -0
- package/templates/skills/business-analyse/html/src/scripts/01-data-init.js +130 -0
- package/templates/skills/business-analyse/html/src/scripts/02-navigation.js +22 -0
- package/templates/skills/business-analyse/html/src/scripts/03-render-cadrage.js +208 -0
- package/templates/skills/business-analyse/html/src/scripts/04-render-modules.js +211 -0
- package/templates/skills/business-analyse/html/src/scripts/05-render-specs.js +554 -0
- package/templates/skills/business-analyse/html/src/scripts/06-render-consolidation.js +110 -0
- package/templates/skills/business-analyse/html/src/scripts/07-render-handoff.js +90 -0
- package/templates/skills/business-analyse/html/src/scripts/08-editing.js +45 -0
- package/templates/skills/business-analyse/html/src/scripts/09-export.js +168 -0
- package/templates/skills/business-analyse/html/src/scripts/10-comments.js +171 -0
- package/templates/skills/business-analyse/html/src/scripts/11-review-panel.js +161 -0
- package/templates/skills/business-analyse/html/src/styles/01-variables.css +38 -0
- package/templates/skills/business-analyse/html/src/styles/02-layout.css +101 -0
- package/templates/skills/business-analyse/html/src/styles/03-navigation.css +62 -0
- package/templates/skills/business-analyse/html/src/styles/04-cards.css +196 -0
- package/templates/skills/business-analyse/html/src/styles/05-modules.css +325 -0
- package/templates/skills/business-analyse/html/src/styles/06-wireframes.css +230 -0
- package/templates/skills/business-analyse/html/src/styles/07-comments.css +184 -0
- package/templates/skills/business-analyse/html/src/styles/08-review-panel.css +241 -0
- package/templates/skills/business-analyse/html/src/template.html +623 -0
- package/templates/skills/business-analyse/references/cadrage-structure-cards.md +78 -0
- package/templates/skills/business-analyse/references/cadrage-vibe-coding.md +97 -0
- package/templates/skills/business-analyse/references/consolidation-structural-checks.md +92 -0
- package/templates/skills/business-analyse/references/deploy-data-build.md +121 -0
- package/templates/skills/business-analyse/references/deploy-modes.md +49 -0
- package/templates/skills/business-analyse/references/handoff-file-templates.md +119 -0
- package/templates/skills/business-analyse/references/handoff-mappings.md +81 -0
- package/templates/skills/business-analyse/references/html-data-mapping.md +10 -2
- package/templates/skills/business-analyse/references/init-schema-deployment.md +65 -0
- package/templates/skills/business-analyse/references/review-data-mapping.md +363 -0
- package/templates/skills/business-analyse/references/spec-auto-inference.md +57 -0
- package/templates/skills/business-analyse/references/ui-dashboard-spec.md +85 -0
- package/templates/skills/business-analyse/references/ui-resource-cards.md +110 -0
- package/templates/skills/business-analyse/references/validate-incremental-html.md +55 -0
- package/templates/skills/business-analyse/steps/step-00-init.md +35 -68
- package/templates/skills/business-analyse/steps/step-01-cadrage.md +5 -194
- package/templates/skills/business-analyse/steps/step-03a-data.md +6 -49
- package/templates/skills/business-analyse/steps/step-03b-ui.md +12 -178
- package/templates/skills/business-analyse/steps/step-03d-validate.md +3 -48
- package/templates/skills/business-analyse/steps/step-04-consolidation.md +9 -104
- package/templates/skills/business-analyse/steps/step-05a-handoff.md +25 -441
- package/templates/skills/business-analyse/steps/step-05b-deploy.md +19 -187
- package/templates/skills/business-analyse/steps/step-06-review.md +277 -0
- package/templates/skills/cc-agent/references/agent-behavior-patterns.md +95 -0
- package/templates/skills/cc-agent/steps/step-02-generate.md +5 -78
- package/templates/skills/check-version/SKILL.md +7 -0
- package/templates/skills/controller/references/controller-code-templates.md +159 -0
- package/templates/skills/controller/references/permission-sync-templates.md +152 -0
- package/templates/skills/controller/steps/step-03-generate.md +6 -158
- package/templates/skills/controller/steps/step-04-perms.md +5 -144
- package/templates/skills/debug/SKILL.md +7 -0
- package/templates/skills/explore/SKILL.md +6 -0
- package/templates/skills/feature-full/SKILL.md +39 -142
- package/templates/skills/feature-full/steps/step-01-implementation.md +120 -0
- package/templates/skills/gitflow/references/init-config-template.md +135 -0
- package/templates/skills/gitflow/references/init-name-normalization.md +103 -0
- package/templates/skills/gitflow/references/plan-template.md +69 -0
- package/templates/skills/gitflow/references/start-efcore-preflight.md +70 -0
- package/templates/skills/gitflow/references/start-local-config.md +110 -0
- package/templates/skills/gitflow/steps/step-init.md +18 -289
- package/templates/skills/gitflow/steps/step-plan.md +6 -63
- package/templates/skills/gitflow/steps/step-start.md +16 -126
- package/templates/skills/mcp/SKILL.md +9 -213
- package/templates/skills/mcp/steps/step-01-healthcheck.md +108 -0
- package/templates/skills/mcp/steps/step-02-tools.md +73 -0
- package/templates/skills/notification/SKILL.md +7 -0
- package/templates/skills/quick-search/SKILL.md +5 -0
- package/templates/skills/ralph-loop/SKILL.md +99 -381
- package/templates/skills/ralph-loop/references/category-rules.md +259 -0
- package/templates/skills/ralph-loop/references/compact-loop.md +182 -0
- package/templates/skills/ralph-loop/references/task-transform-legacy.md +259 -0
- package/templates/skills/ralph-loop/references/team-orchestration.md +189 -0
- package/templates/skills/ralph-loop/steps/step-00-init.md +111 -383
- package/templates/skills/ralph-loop/steps/step-01-task.md +79 -896
- package/templates/skills/ralph-loop/steps/step-02-execute.md +68 -680
- package/templates/skills/ralph-loop/steps/step-03-commit.md +47 -277
- package/templates/skills/ralph-loop/steps/step-04-check.md +124 -607
- package/templates/skills/ralph-loop/steps/step-05-report.md +68 -367
- package/templates/skills/refactor/SKILL.md +12 -176
- package/templates/skills/refactor/steps/step-01-discover.md +60 -0
- package/templates/skills/refactor/steps/step-02-execute.md +67 -0
- package/templates/skills/review-code/SKILL.md +19 -257
- package/templates/skills/review-code/steps/step-01-smartstack.md +96 -0
- package/templates/skills/review-code/steps/step-02-detailed-review.md +80 -0
- package/templates/skills/review-code/steps/step-03-react.md +44 -0
- package/templates/skills/ui-components/SKILL.md +7 -0
- package/templates/skills/utils/SKILL.md +6 -0
- package/templates/skills/validate/SKILL.md +6 -0
- package/templates/skills/validate-feature/SKILL.md +8 -0
- package/templates/skills/workflow/SKILL.md +40 -118
- package/templates/skills/workflow/steps/step-01-implementation.md +84 -0
|
@@ -0,0 +1,623 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="fr">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
+
<title>{{APPLICATION_NAME}} - Analyse metier</title>
|
|
7
|
+
<style>
|
|
8
|
+
<!-- CSS_PLACEHOLDER -->
|
|
9
|
+
</style>
|
|
10
|
+
</head>
|
|
11
|
+
<body>
|
|
12
|
+
<div class="app">
|
|
13
|
+
<!-- ============================================
|
|
14
|
+
HEADER
|
|
15
|
+
============================================ -->
|
|
16
|
+
<header class="header">
|
|
17
|
+
<div class="header-logo">BA</div>
|
|
18
|
+
<span class="header-title">Analyse metier</span>
|
|
19
|
+
<div class="header-sep"></div>
|
|
20
|
+
<span class="header-app-name" id="appName">{{APPLICATION_NAME}}</span>
|
|
21
|
+
<div class="header-spacer"></div>
|
|
22
|
+
<div class="header-actions">
|
|
23
|
+
<button class="btn btn-sm" onclick="saveToLocalStorage()" title="Sauvegarder les modifications dans le navigateur">Sauvegarder</button>
|
|
24
|
+
<button class="btn btn-sm btn-review" onclick="saveReviewJSON()" title="Sauvegarder les corrections pour creer une nouvelle version">Sauvegarder corrections</button>
|
|
25
|
+
<button class="btn btn-sm btn-primary" onclick="exportJSON()" title="Exporter les donnees au format JSON pour l'extraction">Exporter JSON</button>
|
|
26
|
+
<button class="btn btn-sm review-toggle-btn" id="reviewToggleBtn" onclick="toggleReviewPanel()" title="Ouvrir/fermer le panneau de review">
|
|
27
|
+
Review
|
|
28
|
+
<span class="review-badge hidden" id="reviewBadge">0</span>
|
|
29
|
+
</button>
|
|
30
|
+
</div>
|
|
31
|
+
</header>
|
|
32
|
+
|
|
33
|
+
<div class="body" id="appBody">
|
|
34
|
+
<!-- ============================================
|
|
35
|
+
SIDEBAR - Navigation 5 niveaux
|
|
36
|
+
============================================ -->
|
|
37
|
+
<aside class="sidebar">
|
|
38
|
+
<!-- Phase Progress -->
|
|
39
|
+
<div class="phase-progress">
|
|
40
|
+
<div class="phase-dot current" id="phase-1" title="Cadrage">1</div>
|
|
41
|
+
<div class="phase-line" id="pline-1"></div>
|
|
42
|
+
<div class="phase-dot" id="phase-2" title="Decomposition">2</div>
|
|
43
|
+
<div class="phase-line" id="pline-2"></div>
|
|
44
|
+
<div class="phase-dot" id="phase-3" title="Specification">3</div>
|
|
45
|
+
<div class="phase-line" id="pline-3"></div>
|
|
46
|
+
<div class="phase-dot" id="phase-4" title="Consolidation">4</div>
|
|
47
|
+
<div class="phase-line" id="pline-4"></div>
|
|
48
|
+
<div class="phase-dot" id="phase-5" title="Synthese">5</div>
|
|
49
|
+
</div>
|
|
50
|
+
|
|
51
|
+
<!-- Phase 1 : Cadrage -->
|
|
52
|
+
<div class="nav-group">
|
|
53
|
+
<div class="nav-group-title">1. Cadrage</div>
|
|
54
|
+
<a class="nav-item active" onclick="showSection('cadrage-problem')" data-section="cadrage-problem">
|
|
55
|
+
<span class="nav-icon">●</span> Probleme a resoudre
|
|
56
|
+
</a>
|
|
57
|
+
<a class="nav-item" onclick="showSection('cadrage-current')" data-section="cadrage-current" data-vibe-hide>
|
|
58
|
+
<span class="nav-icon">●</span> Situation actuelle
|
|
59
|
+
</a>
|
|
60
|
+
<a class="nav-item" onclick="showSection('cadrage-vision')" data-section="cadrage-vision" data-vibe-hide>
|
|
61
|
+
<span class="nav-icon">●</span> Situation souhaitee
|
|
62
|
+
</a>
|
|
63
|
+
<a class="nav-item" onclick="showSection('cadrage-stakeholders')" data-section="cadrage-stakeholders">
|
|
64
|
+
<span class="nav-icon">●</span> Parties prenantes
|
|
65
|
+
<span class="nav-badge" id="stakeholderCount">0</span>
|
|
66
|
+
</a>
|
|
67
|
+
<a class="nav-item" onclick="showSection('cadrage-scope')" data-section="cadrage-scope">
|
|
68
|
+
<span class="nav-icon">●</span> Perimetre fonctionnel
|
|
69
|
+
</a>
|
|
70
|
+
<a class="nav-item" onclick="showSection('cadrage-risks')" data-section="cadrage-risks">
|
|
71
|
+
<span class="nav-icon">●</span> Risques et hypotheses
|
|
72
|
+
</a>
|
|
73
|
+
<a class="nav-item" onclick="showSection('cadrage-success')" data-section="cadrage-success">
|
|
74
|
+
<span class="nav-icon">●</span> Criteres de reussite
|
|
75
|
+
</a>
|
|
76
|
+
</div>
|
|
77
|
+
|
|
78
|
+
<!-- Phase 2 : Decomposition -->
|
|
79
|
+
<div class="nav-group">
|
|
80
|
+
<div class="nav-group-title">2. Decomposition</div>
|
|
81
|
+
<a class="nav-item" onclick="showSection('decomp-modules')" data-section="decomp-modules">
|
|
82
|
+
<span class="nav-icon">●</span> Domaines fonctionnels
|
|
83
|
+
<span class="nav-badge" id="moduleCount">0</span>
|
|
84
|
+
</a>
|
|
85
|
+
<a class="nav-item" onclick="showSection('decomp-dependencies')" data-section="decomp-dependencies">
|
|
86
|
+
<span class="nav-icon">●</span> Dependances
|
|
87
|
+
</a>
|
|
88
|
+
</div>
|
|
89
|
+
|
|
90
|
+
<!-- Phase 3 : Specification par module -->
|
|
91
|
+
<div class="nav-group" id="modulesNav">
|
|
92
|
+
<div class="nav-group-title">3. Specification</div>
|
|
93
|
+
<!-- Populated dynamically per module -->
|
|
94
|
+
</div>
|
|
95
|
+
|
|
96
|
+
<!-- Phase 4 : Consolidation -->
|
|
97
|
+
<div class="nav-group">
|
|
98
|
+
<div class="nav-group-title">4. Consolidation</div>
|
|
99
|
+
<a class="nav-item" onclick="showSection('consol-interactions')" data-section="consol-interactions">
|
|
100
|
+
<span class="nav-icon">●</span> Interactions
|
|
101
|
+
</a>
|
|
102
|
+
<a class="nav-item" onclick="showSection('consol-permissions')" data-section="consol-permissions">
|
|
103
|
+
<span class="nav-icon">●</span> Coherence des acces
|
|
104
|
+
</a>
|
|
105
|
+
<a class="nav-item" onclick="showSection('consol-flows')" data-section="consol-flows">
|
|
106
|
+
<span class="nav-icon">●</span> Parcours bout en bout
|
|
107
|
+
</a>
|
|
108
|
+
</div>
|
|
109
|
+
|
|
110
|
+
<!-- Phase 5 : Synthese -->
|
|
111
|
+
<div class="nav-group">
|
|
112
|
+
<div class="nav-group-title">5. Synthese</div>
|
|
113
|
+
<a class="nav-item" onclick="showSection('handoff-summary')" data-section="handoff-summary">
|
|
114
|
+
<span class="nav-icon">●</span> Vue d'ensemble
|
|
115
|
+
</a>
|
|
116
|
+
</div>
|
|
117
|
+
</aside>
|
|
118
|
+
|
|
119
|
+
<!-- ============================================
|
|
120
|
+
MAIN CONTENT
|
|
121
|
+
============================================ -->
|
|
122
|
+
<main class="main" id="mainContent">
|
|
123
|
+
|
|
124
|
+
<!-- SECTION: Probleme a resoudre -->
|
|
125
|
+
<div class="section" id="cadrage-problem">
|
|
126
|
+
<h2 class="section-title">Probleme a resoudre</h2>
|
|
127
|
+
<p class="section-subtitle">Decrivez le probleme principal que ce projet doit resoudre. Soyez le plus concret possible.</p>
|
|
128
|
+
|
|
129
|
+
<div class="card">
|
|
130
|
+
<div class="card-label">Description du probleme</div>
|
|
131
|
+
<div class="editable" contenteditable="true" data-field="problem.description" data-placeholder="Decrivez le probleme que vous rencontrez aujourd'hui. Qu'est-ce qui ne fonctionne pas, ou pas assez bien ?"></div>
|
|
132
|
+
</div>
|
|
133
|
+
|
|
134
|
+
<div class="card" data-vibe-hide>
|
|
135
|
+
<div class="card-label">Qui est le plus impacte ?</div>
|
|
136
|
+
<div class="editable" contenteditable="true" data-field="problem.impactedPeople" data-placeholder="Quelles personnes souffrent le plus de ce probleme au quotidien ? Quel impact sur leur travail ?"></div>
|
|
137
|
+
</div>
|
|
138
|
+
|
|
139
|
+
<div class="card" data-vibe-hide>
|
|
140
|
+
<div class="card-label">Depuis quand ce probleme existe-t-il ?</div>
|
|
141
|
+
<div class="editable" contenteditable="true" data-field="problem.history" data-placeholder="Depuis combien de temps ce probleme existe-t-il ? A-t-il empire recemment ?"></div>
|
|
142
|
+
</div>
|
|
143
|
+
|
|
144
|
+
<div class="card">
|
|
145
|
+
<div class="card-label">Evenement declencheur</div>
|
|
146
|
+
<div class="editable" contenteditable="true" data-field="problem.trigger" data-placeholder="Qu'est-ce qui a declenche cette demande maintenant ? Pourquoi pas il y a 6 mois ?"></div>
|
|
147
|
+
</div>
|
|
148
|
+
|
|
149
|
+
<div class="card" data-vibe-hide>
|
|
150
|
+
<div class="card-label">Consequences si le projet n'est pas realise</div>
|
|
151
|
+
<div class="editable" contenteditable="true" data-field="problem.consequences" data-placeholder="Que se passerait-il si ce projet n'etait PAS realise ? Quelles consequences a court et moyen terme ?"></div>
|
|
152
|
+
</div>
|
|
153
|
+
</div>
|
|
154
|
+
|
|
155
|
+
<!-- SECTION: Situation actuelle -->
|
|
156
|
+
<div class="section" id="cadrage-current" style="display:none;" data-vibe-hide>
|
|
157
|
+
<h2 class="section-title">Situation actuelle</h2>
|
|
158
|
+
<p class="section-subtitle">Comment les choses se passent aujourd'hui, concretement.</p>
|
|
159
|
+
|
|
160
|
+
<div class="card">
|
|
161
|
+
<div class="card-label">Outils et methodes utilises aujourd'hui</div>
|
|
162
|
+
<div class="editable" contenteditable="true" data-field="current.tools" data-placeholder="Comment gerez-vous ce sujet aujourd'hui ? Avec quels outils (tableur, email, papier, logiciel) ?"></div>
|
|
163
|
+
</div>
|
|
164
|
+
|
|
165
|
+
<div class="card">
|
|
166
|
+
<div class="card-label">Processus actuel, etape par etape</div>
|
|
167
|
+
<div id="processFlow" class="process-flow">
|
|
168
|
+
<!-- Populated dynamically -->
|
|
169
|
+
</div>
|
|
170
|
+
<button class="add-btn" onclick="addProcessStep()">+ Ajouter une etape au processus</button>
|
|
171
|
+
</div>
|
|
172
|
+
|
|
173
|
+
<div class="card">
|
|
174
|
+
<div class="card-label">Etapes les plus penibles ou les plus longues</div>
|
|
175
|
+
<div class="editable" contenteditable="true" data-field="current.painPoints" data-placeholder="Quelles sont les etapes les plus penibles ou les plus longues dans ce processus ?"></div>
|
|
176
|
+
</div>
|
|
177
|
+
|
|
178
|
+
<div class="card">
|
|
179
|
+
<div class="card-label">Erreurs ou problemes recurrents</div>
|
|
180
|
+
<div class="editable" contenteditable="true" data-field="current.errors" data-placeholder="Quelles erreurs ou problemes reviennent regulierement ? Donnez 2 a 3 exemples concrets."></div>
|
|
181
|
+
</div>
|
|
182
|
+
</div>
|
|
183
|
+
|
|
184
|
+
<!-- SECTION: Situation souhaitee -->
|
|
185
|
+
<div class="section" id="cadrage-vision" style="display:none;" data-vibe-hide>
|
|
186
|
+
<h2 class="section-title">Situation souhaitee</h2>
|
|
187
|
+
<p class="section-subtitle">Ce que le client veut obtenir, pas ce qu'il veut construire.</p>
|
|
188
|
+
|
|
189
|
+
<div class="card">
|
|
190
|
+
<div class="card-label">Ce qui changerait concretement</div>
|
|
191
|
+
<div class="editable" contenteditable="true" data-field="vision.changes" data-placeholder="Si le probleme etait resolu demain, que feriez-vous differemment dans votre journee de travail ?"></div>
|
|
192
|
+
</div>
|
|
193
|
+
|
|
194
|
+
<div class="card">
|
|
195
|
+
<div class="card-label">Resultats attendus (mesurables)</div>
|
|
196
|
+
<div class="editable" contenteditable="true" data-field="vision.results" data-placeholder="Quels resultats concrets attendez-vous ? Citez 2 a 3 ameliorations mesurables."></div>
|
|
197
|
+
</div>
|
|
198
|
+
|
|
199
|
+
<div class="card">
|
|
200
|
+
<div class="card-label">Signe visible de succes</div>
|
|
201
|
+
<div class="editable" contenteditable="true" data-field="vision.successSign" data-placeholder="Comment saurez-vous que le projet est un succes ? Quel est le signe visible ?"></div>
|
|
202
|
+
</div>
|
|
203
|
+
</div>
|
|
204
|
+
|
|
205
|
+
<!-- SECTION: Parties prenantes -->
|
|
206
|
+
<div class="section" id="cadrage-stakeholders" style="display:none;">
|
|
207
|
+
<h2 class="section-title">Parties prenantes</h2>
|
|
208
|
+
<p class="section-subtitle">Toutes les personnes concernees par ce projet et leurs besoins.</p>
|
|
209
|
+
|
|
210
|
+
<div class="stakeholder-grid" id="stakeholderGrid">
|
|
211
|
+
<!-- Populated dynamically -->
|
|
212
|
+
</div>
|
|
213
|
+
|
|
214
|
+
<button class="add-btn" onclick="toggleForm('addStakeholderForm')">+ Ajouter un profil utilisateur</button>
|
|
215
|
+
|
|
216
|
+
<div class="inline-form" id="addStakeholderForm">
|
|
217
|
+
<div class="inline-form-title">Nouveau profil utilisateur</div>
|
|
218
|
+
<div class="form-group">
|
|
219
|
+
<label class="form-label">Titre du profil (exemple : Responsable de production)</label>
|
|
220
|
+
<input type="text" class="form-input" id="sh-role" placeholder="Titre ou description du profil">
|
|
221
|
+
</div>
|
|
222
|
+
<div class="form-group">
|
|
223
|
+
<label class="form-label">Fonction dans l'entreprise</label>
|
|
224
|
+
<input type="text" class="form-input" id="sh-function" placeholder="Ce qu'il fait dans l'organisation">
|
|
225
|
+
</div>
|
|
226
|
+
<div class="form-group">
|
|
227
|
+
<label class="form-label">Taches principales (une par ligne)</label>
|
|
228
|
+
<textarea class="form-textarea" id="sh-tasks" placeholder="Tache 1 Tache 2 Tache 3"></textarea>
|
|
229
|
+
</div>
|
|
230
|
+
<div class="form-row">
|
|
231
|
+
<div class="form-group">
|
|
232
|
+
<label class="form-label">Frequence d'utilisation</label>
|
|
233
|
+
<select class="form-select" id="sh-frequency">
|
|
234
|
+
<option value="daily">Quotidienne</option>
|
|
235
|
+
<option value="weekly">Hebdomadaire</option>
|
|
236
|
+
<option value="monthly">Mensuelle</option>
|
|
237
|
+
<option value="occasional">Occasionnelle</option>
|
|
238
|
+
</select>
|
|
239
|
+
</div>
|
|
240
|
+
<div class="form-group">
|
|
241
|
+
<label class="form-label">Niveau d'acces</label>
|
|
242
|
+
<select class="form-select" id="sh-access">
|
|
243
|
+
<option value="admin">Administration complete</option>
|
|
244
|
+
<option value="manager">Supervision et validation</option>
|
|
245
|
+
<option value="contributor">Saisie et modification</option>
|
|
246
|
+
<option value="viewer">Consultation seule</option>
|
|
247
|
+
</select>
|
|
248
|
+
</div>
|
|
249
|
+
</div>
|
|
250
|
+
<div class="form-group">
|
|
251
|
+
<label class="form-label">Frustrations actuelles</label>
|
|
252
|
+
<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>
|
|
253
|
+
</div>
|
|
254
|
+
<div class="form-actions">
|
|
255
|
+
<button class="btn" onclick="toggleForm('addStakeholderForm')">Annuler</button>
|
|
256
|
+
<button class="btn btn-primary" onclick="addStakeholder()">Ajouter ce profil</button>
|
|
257
|
+
</div>
|
|
258
|
+
</div>
|
|
259
|
+
</div>
|
|
260
|
+
|
|
261
|
+
<!-- SECTION: Perimetre fonctionnel -->
|
|
262
|
+
<div class="section" id="cadrage-scope" style="display:none;">
|
|
263
|
+
<h2 class="section-title">Perimetre fonctionnel</h2>
|
|
264
|
+
<p class="section-subtitle">Ce que le systeme doit faire et ne pas faire, par ordre de priorite.</p>
|
|
265
|
+
|
|
266
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">
|
|
267
|
+
<span style="color: #f87171;">■</span> Fonctionnalites indispensables
|
|
268
|
+
</h3>
|
|
269
|
+
<div id="scopeVital" class="uc-list"></div>
|
|
270
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-vital')">+ Ajouter une fonctionnalite indispensable</button>
|
|
271
|
+
<div class="inline-form" id="addScopeForm-vital">
|
|
272
|
+
<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>
|
|
273
|
+
<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>
|
|
274
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-vital')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('vital')">Ajouter</button></div>
|
|
275
|
+
</div>
|
|
276
|
+
|
|
277
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
278
|
+
<span style="color: #facc15;">■</span> Fonctionnalites importantes
|
|
279
|
+
</h3>
|
|
280
|
+
<div id="scopeImportant" class="uc-list"></div>
|
|
281
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-important')">+ Ajouter une fonctionnalite importante</button>
|
|
282
|
+
<div class="inline-form" id="addScopeForm-important">
|
|
283
|
+
<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>
|
|
284
|
+
<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>
|
|
285
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-important')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('important')">Ajouter</button></div>
|
|
286
|
+
</div>
|
|
287
|
+
|
|
288
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
289
|
+
<span style="color: #4ade80;">■</span> Fonctionnalites optionnelles
|
|
290
|
+
</h3>
|
|
291
|
+
<div id="scopeOptional" class="uc-list"></div>
|
|
292
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-optional')">+ Ajouter une fonctionnalite optionnelle</button>
|
|
293
|
+
<div class="inline-form" id="addScopeForm-optional">
|
|
294
|
+
<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>
|
|
295
|
+
<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>
|
|
296
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-optional')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('optional')">Ajouter</button></div>
|
|
297
|
+
</div>
|
|
298
|
+
|
|
299
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
300
|
+
<span style="color: #94a3b8;">■</span> Hors perimetre
|
|
301
|
+
</h3>
|
|
302
|
+
<div id="scopeExcluded" class="uc-list"></div>
|
|
303
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-excluded')">+ Ajouter une exclusion</button>
|
|
304
|
+
<div class="inline-form" id="addScopeForm-excluded">
|
|
305
|
+
<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>
|
|
306
|
+
<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>
|
|
307
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-excluded')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('excluded')">Ajouter</button></div>
|
|
308
|
+
</div>
|
|
309
|
+
</div>
|
|
310
|
+
|
|
311
|
+
<!-- SECTION: Risques et hypotheses -->
|
|
312
|
+
<div class="section" id="cadrage-risks" style="display:none;">
|
|
313
|
+
<h2 class="section-title">Risques et hypotheses</h2>
|
|
314
|
+
<p class="section-subtitle">Ce qui pourrait mal tourner et les certitudes non verifiees.</p>
|
|
315
|
+
|
|
316
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">Risques identifies</h3>
|
|
317
|
+
<div id="risksList"></div>
|
|
318
|
+
<button class="add-btn" onclick="toggleForm('addRiskForm')">+ Ajouter un risque</button>
|
|
319
|
+
|
|
320
|
+
<div class="inline-form" id="addRiskForm">
|
|
321
|
+
<div class="inline-form-title">Nouveau risque</div>
|
|
322
|
+
<div class="form-group">
|
|
323
|
+
<label class="form-label">Description du risque</label>
|
|
324
|
+
<input type="text" class="form-input" id="risk-desc" placeholder="Qu'est-ce qui pourrait mal tourner ?">
|
|
325
|
+
</div>
|
|
326
|
+
<div class="form-row">
|
|
327
|
+
<div class="form-group">
|
|
328
|
+
<label class="form-label">Probabilite</label>
|
|
329
|
+
<select class="form-select" id="risk-probability">
|
|
330
|
+
<option value="high">Forte</option>
|
|
331
|
+
<option value="medium">Moyenne</option>
|
|
332
|
+
<option value="low">Faible</option>
|
|
333
|
+
</select>
|
|
334
|
+
</div>
|
|
335
|
+
<div class="form-group">
|
|
336
|
+
<label class="form-label">Impact</label>
|
|
337
|
+
<select class="form-select" id="risk-impact">
|
|
338
|
+
<option value="high">Grave</option>
|
|
339
|
+
<option value="medium">Moyen</option>
|
|
340
|
+
<option value="low">Faible</option>
|
|
341
|
+
</select>
|
|
342
|
+
</div>
|
|
343
|
+
</div>
|
|
344
|
+
<div class="form-group">
|
|
345
|
+
<label class="form-label">Mesure de prevention ou de reduction</label>
|
|
346
|
+
<textarea class="form-textarea" id="risk-mitigation" placeholder="Comment prevenir ou reduire ce risque ?"></textarea>
|
|
347
|
+
</div>
|
|
348
|
+
<div class="form-actions">
|
|
349
|
+
<button class="btn" onclick="toggleForm('addRiskForm')">Annuler</button>
|
|
350
|
+
<button class="btn btn-primary" onclick="addRisk()">Ajouter ce risque</button>
|
|
351
|
+
</div>
|
|
352
|
+
</div>
|
|
353
|
+
|
|
354
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Hypotheses a verifier</h3>
|
|
355
|
+
<div class="card">
|
|
356
|
+
<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>
|
|
357
|
+
</div>
|
|
358
|
+
</div>
|
|
359
|
+
|
|
360
|
+
<!-- SECTION: Criteres de reussite -->
|
|
361
|
+
<div class="section" id="cadrage-success" style="display:none;">
|
|
362
|
+
<h2 class="section-title">Criteres de reussite</h2>
|
|
363
|
+
<p class="section-subtitle">Comment mesurer objectivement que le projet est un succes.</p>
|
|
364
|
+
|
|
365
|
+
<div class="card">
|
|
366
|
+
<div class="card-label">Definition du succes</div>
|
|
367
|
+
<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>
|
|
368
|
+
</div>
|
|
369
|
+
|
|
370
|
+
<div class="card" data-vibe-hide>
|
|
371
|
+
<div class="card-label">Objectifs mesurables</div>
|
|
372
|
+
<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>
|
|
373
|
+
</div>
|
|
374
|
+
|
|
375
|
+
<div class="card" data-vibe-hide>
|
|
376
|
+
<div class="card-label">Delai d'evaluation</div>
|
|
377
|
+
<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>
|
|
378
|
+
</div>
|
|
379
|
+
|
|
380
|
+
<div class="card" data-vibe-hide>
|
|
381
|
+
<div class="card-label">Conditions minimales de mise en service</div>
|
|
382
|
+
<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>
|
|
383
|
+
</div>
|
|
384
|
+
|
|
385
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Criteres d'acceptation</h3>
|
|
386
|
+
<p style="font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem;">Criteres concrets et mesurables pour valider le succes du projet.</p>
|
|
387
|
+
<div id="criteriaList" class="uc-list"></div>
|
|
388
|
+
<button class="add-btn" onclick="toggleForm('addCriterionForm')">+ Ajouter un critere d'acceptation</button>
|
|
389
|
+
<div class="inline-form" id="addCriterionForm">
|
|
390
|
+
<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>
|
|
391
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addCriterionForm')">Annuler</button><button class="btn btn-primary" onclick="addCriterion()">Ajouter</button></div>
|
|
392
|
+
</div>
|
|
393
|
+
</div>
|
|
394
|
+
|
|
395
|
+
<!-- ================================================================
|
|
396
|
+
PHASE 2 : DECOMPOSITION
|
|
397
|
+
================================================================ -->
|
|
398
|
+
|
|
399
|
+
<!-- SECTION: Domaines fonctionnels -->
|
|
400
|
+
<div class="section" id="decomp-modules" style="display:none;">
|
|
401
|
+
<h2 class="section-title">Domaines fonctionnels</h2>
|
|
402
|
+
<p class="section-subtitle">Identifiez les grands domaines de votre application. Chaque domaine regroupe des fonctionnalites coherentes et independantes.</p>
|
|
403
|
+
|
|
404
|
+
<div class="module-grid" id="moduleGrid">
|
|
405
|
+
<!-- Populated dynamically -->
|
|
406
|
+
</div>
|
|
407
|
+
|
|
408
|
+
<button class="add-btn" onclick="toggleForm('addModuleForm')" style="margin-top:1rem;">+ Ajouter un domaine fonctionnel</button>
|
|
409
|
+
|
|
410
|
+
<div class="inline-form" id="addModuleForm">
|
|
411
|
+
<div class="inline-form-title">Nouveau domaine fonctionnel</div>
|
|
412
|
+
<div class="form-group">
|
|
413
|
+
<label class="form-label">Nom du domaine (exemple : Gestion des commandes)</label>
|
|
414
|
+
<input type="text" class="form-input" id="mod-name" placeholder="Nom clair et explicite">
|
|
415
|
+
</div>
|
|
416
|
+
<div class="form-group">
|
|
417
|
+
<label class="form-label">Description en une ou deux phrases</label>
|
|
418
|
+
<textarea class="form-textarea" id="mod-desc" placeholder="A quoi sert ce domaine ? Quel probleme resout-il ?"></textarea>
|
|
419
|
+
</div>
|
|
420
|
+
<div class="form-row">
|
|
421
|
+
<div class="form-group">
|
|
422
|
+
<label class="form-label">Type de domaine</label>
|
|
423
|
+
<select class="form-select" id="mod-type">
|
|
424
|
+
<option value="data-centric">Gestion de donnees (listes, fiches, formulaires)</option>
|
|
425
|
+
<option value="workflow">Processus metier (etapes, validations, approbations)</option>
|
|
426
|
+
<option value="reporting">Tableaux de bord et rapports</option>
|
|
427
|
+
<option value="integration">Integration avec des systemes externes</option>
|
|
428
|
+
<option value="full-module">Domaine complet (donnees + processus + rapports)</option>
|
|
429
|
+
</select>
|
|
430
|
+
</div>
|
|
431
|
+
<div class="form-group">
|
|
432
|
+
<label class="form-label">Priorite</label>
|
|
433
|
+
<select class="form-select" id="mod-priority">
|
|
434
|
+
<option value="must">Indispensable</option>
|
|
435
|
+
<option value="should">Important</option>
|
|
436
|
+
<option value="could">Optionnel</option>
|
|
437
|
+
</select>
|
|
438
|
+
</div>
|
|
439
|
+
</div>
|
|
440
|
+
<div class="form-group">
|
|
441
|
+
<label class="form-label">Principales donnees gerees (une par ligne)</label>
|
|
442
|
+
<textarea class="form-textarea" id="mod-entities" placeholder="Commande Ligne de commande Facture"></textarea>
|
|
443
|
+
</div>
|
|
444
|
+
<div class="form-actions">
|
|
445
|
+
<button class="btn" onclick="toggleForm('addModuleForm')">Annuler</button>
|
|
446
|
+
<button class="btn btn-primary" onclick="addModule()">Ajouter ce domaine</button>
|
|
447
|
+
</div>
|
|
448
|
+
</div>
|
|
449
|
+
</div>
|
|
450
|
+
|
|
451
|
+
<!-- SECTION: Dependances -->
|
|
452
|
+
<div class="section" id="decomp-dependencies" style="display:none;">
|
|
453
|
+
<h2 class="section-title">Dependances entre domaines</h2>
|
|
454
|
+
<p class="section-subtitle">Indiquez quels domaines dependent d'autres domaines. Par exemple, les Commandes dependent des Clients et des Produits.</p>
|
|
455
|
+
|
|
456
|
+
<div id="depGraphContainer">
|
|
457
|
+
<div class="dep-graph" id="depGraph">
|
|
458
|
+
<p style="color:var(--text-muted);text-align:center;padding:2rem;">Ajoutez des domaines fonctionnels pour visualiser les dependances.</p>
|
|
459
|
+
</div>
|
|
460
|
+
</div>
|
|
461
|
+
|
|
462
|
+
<div style="margin-top:1.5rem;">
|
|
463
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ajouter une dependance</h3>
|
|
464
|
+
<div class="form-row">
|
|
465
|
+
<div class="form-group">
|
|
466
|
+
<label class="form-label">Ce domaine...</label>
|
|
467
|
+
<select class="form-select" id="dep-from"></select>
|
|
468
|
+
</div>
|
|
469
|
+
<div class="form-group">
|
|
470
|
+
<label class="form-label">...depend de</label>
|
|
471
|
+
<select class="form-select" id="dep-to"></select>
|
|
472
|
+
</div>
|
|
473
|
+
</div>
|
|
474
|
+
<div class="form-group">
|
|
475
|
+
<label class="form-label">Nature de la dependance</label>
|
|
476
|
+
<input type="text" class="form-input" id="dep-desc" placeholder="Exemple : La commande reference un client existant">
|
|
477
|
+
</div>
|
|
478
|
+
<button class="btn btn-primary" onclick="addDependency()" style="margin-top:0.5rem;">Ajouter cette dependance</button>
|
|
479
|
+
</div>
|
|
480
|
+
|
|
481
|
+
<div id="depList" style="margin-top:1.5rem;"></div>
|
|
482
|
+
|
|
483
|
+
<div style="margin-top:2rem;">
|
|
484
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ordre de traitement propose</h3>
|
|
485
|
+
<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>
|
|
486
|
+
<div id="processingOrder" class="process-flow"></div>
|
|
487
|
+
</div>
|
|
488
|
+
</div>
|
|
489
|
+
|
|
490
|
+
<!-- ================================================================
|
|
491
|
+
PHASE 3 : SPECIFICATION PAR MODULE
|
|
492
|
+
================================================================ -->
|
|
493
|
+
|
|
494
|
+
<!-- Container dynamique pour les specs de chaque module -->
|
|
495
|
+
<div id="moduleSpecContainer">
|
|
496
|
+
<!-- Generated dynamically by renderModuleSpec() -->
|
|
497
|
+
</div>
|
|
498
|
+
|
|
499
|
+
<!-- ================================================================
|
|
500
|
+
PHASE 4 : CONSOLIDATION
|
|
501
|
+
================================================================ -->
|
|
502
|
+
|
|
503
|
+
<!-- SECTION: Interactions cross-module -->
|
|
504
|
+
<div class="section" id="consol-interactions" style="display:none;">
|
|
505
|
+
<h2 class="section-title">Interactions entre domaines</h2>
|
|
506
|
+
<p class="section-subtitle">Vue d'ensemble de la facon dont les domaines communiquent et partagent des donnees.</p>
|
|
507
|
+
<div id="consolInteractions">
|
|
508
|
+
<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>
|
|
509
|
+
</div>
|
|
510
|
+
</div>
|
|
511
|
+
|
|
512
|
+
<!-- SECTION: Coherence des acces -->
|
|
513
|
+
<div class="section" id="consol-permissions" style="display:none;">
|
|
514
|
+
<h2 class="section-title">Coherence des droits d'acces</h2>
|
|
515
|
+
<p class="section-subtitle">Verification que les profils utilisateurs ont des droits coherents dans tous les domaines.</p>
|
|
516
|
+
<div id="consolPermissions">
|
|
517
|
+
<p style="color:var(--text-muted);text-align:center;padding:2rem;">La coherence sera verifiee quand les permissions de chaque domaine seront definies.</p>
|
|
518
|
+
</div>
|
|
519
|
+
</div>
|
|
520
|
+
|
|
521
|
+
<!-- SECTION: Parcours bout en bout -->
|
|
522
|
+
<div class="section" id="consol-flows" style="display:none;">
|
|
523
|
+
<h2 class="section-title">Parcours bout en bout</h2>
|
|
524
|
+
<p class="section-subtitle">Les processus metier qui traversent plusieurs domaines, de bout en bout.</p>
|
|
525
|
+
|
|
526
|
+
<div id="e2eFlowsList"></div>
|
|
527
|
+
|
|
528
|
+
<button class="add-btn" onclick="toggleForm('addFlowForm')">+ Ajouter un parcours</button>
|
|
529
|
+
|
|
530
|
+
<div class="inline-form" id="addFlowForm">
|
|
531
|
+
<div class="inline-form-title">Nouveau parcours bout en bout</div>
|
|
532
|
+
<div class="form-group">
|
|
533
|
+
<label class="form-label">Nom du parcours (exemple : De la commande a la facture)</label>
|
|
534
|
+
<input type="text" class="form-input" id="flow-name" placeholder="Nom descriptif du parcours">
|
|
535
|
+
</div>
|
|
536
|
+
<div class="form-group">
|
|
537
|
+
<label class="form-label">Etapes du parcours (une par ligne : Domaine - Action)</label>
|
|
538
|
+
<textarea class="form-textarea" id="flow-steps" placeholder="Clients - Le client existe dans le systeme Commandes - Creer la commande Commandes - Valider la commande Factures - Generer la facture"></textarea>
|
|
539
|
+
</div>
|
|
540
|
+
<div class="form-group">
|
|
541
|
+
<label class="form-label">Qui intervient dans ce parcours ?</label>
|
|
542
|
+
<input type="text" class="form-input" id="flow-actors" placeholder="Exemple : Contributeur (creation), Responsable (validation)">
|
|
543
|
+
</div>
|
|
544
|
+
<div class="form-actions">
|
|
545
|
+
<button class="btn" onclick="toggleForm('addFlowForm')">Annuler</button>
|
|
546
|
+
<button class="btn btn-primary" onclick="addE2EFlow()">Ajouter ce parcours</button>
|
|
547
|
+
</div>
|
|
548
|
+
</div>
|
|
549
|
+
</div>
|
|
550
|
+
|
|
551
|
+
<!-- ================================================================
|
|
552
|
+
PHASE 5 : SYNTHESE
|
|
553
|
+
================================================================ -->
|
|
554
|
+
|
|
555
|
+
<div class="section" id="handoff-summary" style="display:none;">
|
|
556
|
+
<h2 class="section-title">Synthese de l'analyse</h2>
|
|
557
|
+
<p class="section-subtitle">Vue d'ensemble de toute l'analyse metier, prete pour le developpement.</p>
|
|
558
|
+
|
|
559
|
+
<div class="stat-grid" id="handoffStats">
|
|
560
|
+
<!-- Populated dynamically -->
|
|
561
|
+
</div>
|
|
562
|
+
|
|
563
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Domaines par ordre de traitement</h3>
|
|
564
|
+
<div id="handoffModuleList"></div>
|
|
565
|
+
|
|
566
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin:1.5rem 0 0.75rem;">Couverture du besoin initial</h3>
|
|
567
|
+
<div class="card">
|
|
568
|
+
<div class="card-label">Matrice de couverture</div>
|
|
569
|
+
<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>
|
|
570
|
+
<div id="coverageMatrix"></div>
|
|
571
|
+
</div>
|
|
572
|
+
|
|
573
|
+
<div style="margin-top:2rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;text-align:center;">
|
|
574
|
+
<p style="color:var(--text-bright);font-size:1.1rem;font-weight:600;margin-bottom:0.5rem;">Analyse prete pour l'extraction</p>
|
|
575
|
+
<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>
|
|
576
|
+
<button class="btn btn-primary" onclick="exportJSON()" style="font-size:0.9rem;padding:0.6rem 1.5rem;">Exporter l'analyse complete en JSON</button>
|
|
577
|
+
</div>
|
|
578
|
+
</div>
|
|
579
|
+
|
|
580
|
+
</main>
|
|
581
|
+
|
|
582
|
+
<!-- ============================================
|
|
583
|
+
REVIEW PANEL (right sidebar)
|
|
584
|
+
============================================ -->
|
|
585
|
+
<aside class="review-panel" id="reviewPanel">
|
|
586
|
+
<div class="review-panel-header">
|
|
587
|
+
<span class="review-panel-title">Review</span>
|
|
588
|
+
<button class="review-panel-close" onclick="toggleReviewPanel()" title="Fermer">×</button>
|
|
589
|
+
</div>
|
|
590
|
+
<div class="review-filters">
|
|
591
|
+
<button class="review-filter-btn active" onclick="filterReviewComments('all')" data-filter="all">Tous</button>
|
|
592
|
+
<button class="review-filter-btn" onclick="filterReviewComments('to-review')" data-filter="to-review">A revoir</button>
|
|
593
|
+
<button class="review-filter-btn" onclick="filterReviewComments('validated')" data-filter="validated">Valides</button>
|
|
594
|
+
</div>
|
|
595
|
+
<div class="review-comments" id="reviewCommentsList">
|
|
596
|
+
<div class="review-empty">Aucun commentaire pour le moment.</div>
|
|
597
|
+
</div>
|
|
598
|
+
<div class="review-stats" id="reviewStats">
|
|
599
|
+
<div class="review-stat">
|
|
600
|
+
<div class="review-stat-value" id="reviewStatTotal">0</div>
|
|
601
|
+
<div class="review-stat-label">Total</div>
|
|
602
|
+
</div>
|
|
603
|
+
<div class="review-stat">
|
|
604
|
+
<div class="review-stat-value" id="reviewStatToReview">0</div>
|
|
605
|
+
<div class="review-stat-label">A revoir</div>
|
|
606
|
+
</div>
|
|
607
|
+
<div class="review-stat">
|
|
608
|
+
<div class="review-stat-value" id="reviewStatValidated">0</div>
|
|
609
|
+
<div class="review-stat-label">Valides</div>
|
|
610
|
+
</div>
|
|
611
|
+
</div>
|
|
612
|
+
</aside>
|
|
613
|
+
</div>
|
|
614
|
+
</div>
|
|
615
|
+
|
|
616
|
+
<!-- Notification -->
|
|
617
|
+
<div class="notification notification-success" id="notification"></div>
|
|
618
|
+
|
|
619
|
+
<script>
|
|
620
|
+
<!-- JS_PLACEHOLDER -->
|
|
621
|
+
</script>
|
|
622
|
+
</body>
|
|
623
|
+
</html>
|