@atlashub/smartstack-cli 3.39.0 → 3.40.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/.documentation/apex.html +644 -644
- package/.documentation/css/styles.css +2320 -2320
- package/.documentation/init.html +1377 -1377
- package/.documentation/js/app.js +780 -780
- package/.documentation/prd-json-v2.0.0.md +396 -396
- package/.documentation/testing-ba-e2e.md +462 -462
- package/config/default-config.json +95 -95
- package/config/mcp-defaults.json +62 -62
- package/config/settings.json +53 -53
- package/config/settings.local.example.json +16 -16
- package/dist/index.js.map +1 -1
- package/dist/mcp-entry.mjs +6 -4
- package/dist/mcp-entry.mjs.map +1 -1
- package/package.json +115 -115
- package/scripts/extract-api-endpoints.ts +325 -325
- package/scripts/extract-business-rules.ts +440 -440
- package/scripts/generate-doc-with-mock-ui.ts +804 -804
- package/scripts/health-check.sh +168 -168
- package/scripts/postinstall.js +18 -18
- package/templates/agents/action.md +37 -37
- package/templates/agents/ba-reader.md +378 -378
- package/templates/agents/ba-writer.md +861 -861
- package/templates/agents/code-reviewer.md +163 -163
- package/templates/agents/db-reader.md +149 -149
- package/templates/agents/docs-context-reader.md +143 -143
- package/templates/agents/docs-sync-checker.md +122 -122
- package/templates/agents/efcore/conflicts.md +84 -84
- package/templates/agents/efcore/db-deploy.md +74 -74
- package/templates/agents/efcore/db-reset.md +85 -85
- package/templates/agents/efcore/db-seed.md +61 -61
- package/templates/agents/efcore/db-status.md +86 -86
- package/templates/agents/efcore/migration.md +186 -186
- package/templates/agents/efcore/rebase-snapshot.md +108 -108
- package/templates/agents/efcore/scan.md +92 -92
- package/templates/agents/efcore/squash.md +161 -161
- package/templates/agents/explore-codebase.md +66 -66
- package/templates/agents/explore-docs.md +98 -98
- package/templates/agents/fix-grammar.md +50 -50
- package/templates/agents/gitflow/abort.md +45 -45
- package/templates/agents/gitflow/cleanup.md +96 -96
- package/templates/agents/gitflow/commit.md +236 -236
- package/templates/agents/gitflow/exec.md +48 -48
- package/templates/agents/gitflow/finish.md +146 -146
- package/templates/agents/gitflow/init-clone.md +199 -199
- package/templates/agents/gitflow/init-detect.md +137 -137
- package/templates/agents/gitflow/init-validate.md +225 -225
- package/templates/agents/gitflow/init.md +340 -340
- package/templates/agents/gitflow/merge.md +145 -145
- package/templates/agents/gitflow/plan.md +42 -42
- package/templates/agents/gitflow/pr.md +191 -191
- package/templates/agents/gitflow/review.md +49 -49
- package/templates/agents/gitflow/start.md +147 -147
- package/templates/agents/gitflow/status.md +95 -95
- package/templates/agents/mcp-healthcheck.md +163 -163
- package/templates/agents/snipper.md +37 -37
- package/templates/agents/websearch.md +46 -46
- package/templates/hooks/appsettings-guard.sh +76 -76
- package/templates/hooks/docs-drift-check.md +96 -96
- package/templates/hooks/ef-migration-check.md +139 -139
- package/templates/hooks/hooks.json +58 -58
- package/templates/hooks/mcp-check.md +64 -64
- package/templates/hooks/ralph-mcp-logger.sh +46 -46
- package/templates/hooks/ralph-session-end.sh +69 -69
- package/templates/hooks/stop-hook.sh +177 -177
- package/templates/hooks/wsl-dotnet-cleanup.sh +24 -24
- package/templates/mcp-scaffolding/component.tsx.hbs +318 -318
- package/templates/mcp-scaffolding/controller.cs.hbs +192 -192
- package/templates/mcp-scaffolding/entity-extension.cs.hbs +239 -239
- package/templates/mcp-scaffolding/frontend/api-client.ts.hbs +116 -116
- package/templates/mcp-scaffolding/frontend/nav-routes.ts.hbs +133 -133
- package/templates/mcp-scaffolding/frontend/routes.tsx.hbs +126 -126
- package/templates/mcp-scaffolding/migrations/seed-roles.cs.hbs +261 -261
- package/templates/mcp-scaffolding/service-extension.cs.hbs +53 -53
- package/templates/mcp-scaffolding/tests/controller.test.cs.hbs +436 -436
- package/templates/mcp-scaffolding/tests/entity.test.cs.hbs +239 -239
- package/templates/mcp-scaffolding/tests/repository.test.cs.hbs +441 -441
- package/templates/mcp-scaffolding/tests/security.test.cs.hbs +442 -442
- package/templates/mcp-scaffolding/tests/service.test.cs.hbs +402 -402
- package/templates/mcp-scaffolding/tests/validator.test.cs.hbs +428 -428
- package/templates/project/DependencyInjection.Application.cs.template +25 -25
- package/templates/project/DependencyInjection.Infrastructure.cs.template +61 -61
- package/templates/project/DesignTimeExtensionsDbContextFactory.cs.template +70 -70
- package/templates/project/ExampleEntity.cs.template +116 -116
- package/templates/project/ExampleEntityConfiguration.cs.template +64 -64
- package/templates/project/ExampleService.cs.template +146 -146
- package/templates/project/ExtensionsDbContext.cs.template +41 -41
- package/templates/project/IExtensionsDbContext.cs.template +22 -22
- package/templates/project/Program.cs.template +47 -47
- package/templates/project/README.md +79 -79
- package/templates/project/api.ts.template +12 -12
- package/templates/project/appsettings.json.template +170 -170
- package/templates/project/claude-settings.json.template +5 -5
- package/templates/project/test-frontend/msw/handlers.ts +58 -58
- package/templates/project/test-frontend/msw/server.ts +25 -25
- package/templates/project/test-frontend/setup.ts +16 -16
- package/templates/project/test-frontend/test-utils.tsx +59 -59
- package/templates/project/test-frontend/vitest.config.ts +31 -31
- package/templates/ralph/README.md +93 -93
- package/templates/ralph/ralph.config.yaml +113 -113
- package/templates/scripts/setup-ralph-loop.sh +173 -173
- package/templates/skills/_resources/config-safety.md +61 -61
- package/templates/skills/_resources/context-digest-template.md +53 -53
- package/templates/skills/_resources/doc-context-cache.md +60 -60
- package/templates/skills/_resources/docs-manifest-schema.md +155 -155
- package/templates/skills/_resources/formatting-guide.md +124 -124
- package/templates/skills/_resources/mcp-validate-documentation-spec.md +181 -181
- package/templates/skills/_shared.md +228 -228
- package/templates/skills/admin/SKILL.md +48 -48
- package/templates/skills/ai-prompt/SKILL.md +107 -107
- package/templates/skills/ai-prompt/steps/step-00-init.md +47 -47
- package/templates/skills/ai-prompt/steps/step-01-implementation.md +122 -122
- package/templates/skills/apex/SKILL.md +168 -168
- package/templates/skills/apex/_shared.md +141 -141
- package/templates/skills/apex/references/agent-teams-protocol.md +164 -164
- package/templates/skills/apex/references/analysis-methods.md +141 -141
- package/templates/skills/apex/references/challenge-questions.md +145 -145
- package/templates/skills/apex/references/code-generation.md +412 -412
- package/templates/skills/apex/references/core-seed-data.md +1437 -1437
- package/templates/skills/apex/references/error-classification.md +144 -144
- package/templates/skills/apex/references/examine-build-validation.md +82 -82
- package/templates/skills/apex/references/execution-frontend-gates.md +177 -177
- package/templates/skills/apex/references/execution-frontend-patterns.md +105 -105
- package/templates/skills/apex/references/execution-layer1-rules.md +96 -96
- package/templates/skills/apex/references/initialization-challenge-flow.md +110 -110
- package/templates/skills/apex/references/planning-layer-mapping.md +151 -151
- package/templates/skills/apex/references/post-checks.md +1584 -1584
- package/templates/skills/apex/references/smartstack-api.md +1053 -1053
- package/templates/skills/apex/references/smartstack-frontend.md +1571 -1571
- package/templates/skills/apex/references/smartstack-layers.md +402 -402
- package/templates/skills/apex/steps/step-00-init.md +307 -307
- package/templates/skills/apex/steps/step-01-analyze.md +165 -165
- package/templates/skills/apex/steps/step-02-plan.md +144 -144
- package/templates/skills/apex/steps/step-03-execute.md +328 -328
- package/templates/skills/apex/steps/step-04-examine.md +263 -263
- package/templates/skills/apex/steps/step-05-deep-review.md +129 -129
- package/templates/skills/apex/steps/step-06-resolve.md +101 -101
- package/templates/skills/apex/steps/step-07-tests.md +238 -238
- package/templates/skills/apex/steps/step-08-run-tests.md +125 -125
- package/templates/skills/application/SKILL.md +4 -4
- package/templates/skills/application/references/application-roles-template.md +227 -227
- package/templates/skills/application/references/backend-controller-hierarchy.md +58 -58
- package/templates/skills/application/references/backend-entity-seeding.md +72 -72
- package/templates/skills/application/references/backend-seeding-and-dto-output.md +83 -83
- package/templates/skills/application/references/backend-table-prefix-mapping.md +79 -79
- package/templates/skills/application/references/backend-verification.md +88 -88
- package/templates/skills/application/references/frontend-i18n-and-output.md +67 -67
- package/templates/skills/application/references/frontend-route-naming.md +117 -117
- package/templates/skills/application/references/frontend-route-wiring-app-tsx.md +107 -107
- package/templates/skills/application/references/frontend-verification.md +156 -156
- package/templates/skills/application/references/migration-checklist-troubleshooting.md +1 -1
- package/templates/skills/application/references/provider-template.md +177 -177
- package/templates/skills/application/references/roles-client-project-handling.md +55 -55
- package/templates/skills/application/references/roles-fallback-procedure.md +149 -149
- package/templates/skills/application/references/test-coverage-requirements.md +213 -213
- package/templates/skills/application/references/test-frontend.md +73 -73
- package/templates/skills/application/references/test-prerequisites.md +72 -72
- package/templates/skills/application/steps/step-05-frontend.md +176 -176
- package/templates/skills/application/steps/step-06-migration.md +193 -193
- package/templates/skills/application/steps/step-07-tests.md +356 -356
- package/templates/skills/application/steps/step-08-documentation.md +137 -137
- package/templates/skills/application/templates-backend.md +463 -463
- package/templates/skills/application/templates-frontend.md +685 -685
- package/templates/skills/application/templates-i18n.md +520 -520
- package/templates/skills/application/templates-seed.md +1096 -1096
- package/templates/skills/business-analyse/SKILL.md +327 -327
- package/templates/skills/business-analyse/_architecture.md +123 -123
- package/templates/skills/business-analyse/_elicitation.md +206 -206
- package/templates/skills/business-analyse/_module-loop.md +115 -115
- package/templates/skills/business-analyse/_shared.md +383 -383
- package/templates/skills/business-analyse/_suggestions.md +34 -34
- package/templates/skills/business-analyse/html/ba-interactive.html +4477 -4477
- package/templates/skills/business-analyse/html/build-html.js +77 -77
- package/templates/skills/business-analyse/html/src/scripts/01-data-init.js +150 -150
- package/templates/skills/business-analyse/html/src/scripts/02-navigation.js +227 -227
- package/templates/skills/business-analyse/html/src/scripts/03-render-cadrage.js +199 -199
- package/templates/skills/business-analyse/html/src/scripts/04-render-modules.js +205 -205
- package/templates/skills/business-analyse/html/src/scripts/05-render-specs.js +647 -647
- package/templates/skills/business-analyse/html/src/scripts/06-render-consolidation.js +195 -195
- package/templates/skills/business-analyse/html/src/scripts/07-render-handoff.js +92 -92
- package/templates/skills/business-analyse/html/src/scripts/08-editing.js +135 -135
- package/templates/skills/business-analyse/html/src/scripts/09-export.js +168 -168
- package/templates/skills/business-analyse/html/src/scripts/10-comments.js +171 -171
- package/templates/skills/business-analyse/html/src/scripts/11-review-panel.js +166 -166
- package/templates/skills/business-analyse/html/src/styles/01-variables.css +38 -38
- package/templates/skills/business-analyse/html/src/styles/02-layout.css +101 -101
- package/templates/skills/business-analyse/html/src/styles/03-navigation.css +120 -120
- package/templates/skills/business-analyse/html/src/styles/04-cards.css +196 -196
- package/templates/skills/business-analyse/html/src/styles/05-modules.css +454 -454
- package/templates/skills/business-analyse/html/src/styles/06-wireframes.css +272 -272
- package/templates/skills/business-analyse/html/src/styles/07-comments.css +184 -184
- package/templates/skills/business-analyse/html/src/styles/08-review-panel.css +241 -241
- package/templates/skills/business-analyse/html/src/template.html +516 -516
- package/templates/skills/business-analyse/patterns/suggestion-catalog.md +546 -546
- package/templates/skills/business-analyse/questionnaire/00-application.md +160 -160
- package/templates/skills/business-analyse/questionnaire/00b-project.md +85 -85
- package/templates/skills/business-analyse/questionnaire/01-context.md +185 -185
- package/templates/skills/business-analyse/questionnaire/02-stakeholders.md +189 -189
- package/templates/skills/business-analyse/questionnaire/03-scope.md +164 -164
- package/templates/skills/business-analyse/questionnaire/04-data.md +88 -88
- package/templates/skills/business-analyse/questionnaire/05-integrations.md +58 -58
- package/templates/skills/business-analyse/questionnaire/06-security.md +68 -68
- package/templates/skills/business-analyse/questionnaire/07-ui.md +76 -76
- package/templates/skills/business-analyse/questionnaire/08-performance.md +42 -42
- package/templates/skills/business-analyse/questionnaire/09-constraints.md +45 -45
- package/templates/skills/business-analyse/questionnaire/10-documentation.md +43 -43
- package/templates/skills/business-analyse/questionnaire/11-data-lifecycle.md +59 -59
- package/templates/skills/business-analyse/questionnaire/12-migration.md +58 -58
- package/templates/skills/business-analyse/questionnaire/13-cross-module.md +69 -69
- package/templates/skills/business-analyse/questionnaire/14-risk-assumptions.md +135 -135
- package/templates/skills/business-analyse/questionnaire/15-success-metrics.md +136 -136
- package/templates/skills/business-analyse/questionnaire.md +337 -337
- package/templates/skills/business-analyse/react/application-viewer.md +242 -242
- package/templates/skills/business-analyse/react/components.md +551 -551
- package/templates/skills/business-analyse/react/i18n-template.md +306 -306
- package/templates/skills/business-analyse/references/acceptance-criteria.md +169 -169
- package/templates/skills/business-analyse/references/agent-module-prompt.md +362 -362
- package/templates/skills/business-analyse/references/agent-pooling-best-practices.md +557 -557
- package/templates/skills/business-analyse/references/analysis-semantic-checks.md +190 -190
- package/templates/skills/business-analyse/references/cache-warming-strategy.md +566 -566
- package/templates/skills/business-analyse/references/cadrage-challenge-patterns.md +41 -41
- package/templates/skills/business-analyse/references/cadrage-coverage-matrix.md +74 -74
- package/templates/skills/business-analyse/references/cadrage-pre-analysis.md +115 -115
- package/templates/skills/business-analyse/references/cadrage-shared-modules.md +68 -69
- package/templates/skills/business-analyse/references/cadrage-structure-cards.md +85 -85
- package/templates/skills/business-analyse/references/compilation-structure-cards.md +297 -297
- package/templates/skills/business-analyse/references/consolidation-structural-checks.md +107 -107
- package/templates/skills/business-analyse/references/deploy-data-build.md +180 -180
- package/templates/skills/business-analyse/references/deploy-modes.md +118 -118
- package/templates/skills/business-analyse/references/detection-strategies.md +424 -424
- package/templates/skills/business-analyse/references/entity-architecture-decision.md +218 -218
- package/templates/skills/business-analyse/references/handoff-file-templates.md +120 -120
- package/templates/skills/business-analyse/references/handoff-mappings.md +81 -81
- package/templates/skills/business-analyse/references/handoff-seeddata-generation.md +312 -312
- package/templates/skills/business-analyse/references/html-data-mapping.md +299 -299
- package/templates/skills/business-analyse/references/init-schema-deployment.md +65 -65
- package/templates/skills/business-analyse/references/naming-conventions.md +243 -243
- package/templates/skills/business-analyse/references/prd-generation.md +258 -258
- package/templates/skills/business-analyse/references/review-data-mapping.md +363 -363
- package/templates/skills/business-analyse/references/robustness-checks.md +542 -542
- package/templates/skills/business-analyse/references/spec-auto-inference.md +111 -111
- package/templates/skills/business-analyse/references/team-orchestration.md +1022 -1022
- package/templates/skills/business-analyse/references/ui-dashboard-spec.md +85 -85
- package/templates/skills/business-analyse/references/ui-resource-cards.md +259 -259
- package/templates/skills/business-analyse/references/validate-incremental-html.md +121 -121
- package/templates/skills/business-analyse/references/validation-checklist.md +347 -347
- package/templates/skills/business-analyse/references/wireframe-svg-style-guide.md +335 -335
- package/templates/skills/business-analyse/schemas/application-schema.json +453 -453
- package/templates/skills/business-analyse/schemas/feature-schema.json +53 -53
- package/templates/skills/business-analyse/schemas/project-schema.json +485 -485
- package/templates/skills/business-analyse/schemas/sections/analysis-schema.json +201 -201
- package/templates/skills/business-analyse/schemas/sections/discovery-schema.json +82 -82
- package/templates/skills/business-analyse/schemas/sections/handoff-schema.json +80 -80
- package/templates/skills/business-analyse/schemas/sections/metadata-schema.json +70 -70
- package/templates/skills/business-analyse/schemas/sections/specification-schema.json +547 -547
- package/templates/skills/business-analyse/schemas/sections/validation-schema.json +93 -93
- package/templates/skills/business-analyse/schemas/shared/common-defs.json +226 -226
- package/templates/skills/business-analyse/steps/step-00-init.md +575 -576
- package/templates/skills/business-analyse/steps/step-01-cadrage.md +767 -767
- package/templates/skills/business-analyse/steps/step-01b-applications.md +419 -419
- package/templates/skills/business-analyse/steps/step-02-decomposition.md +387 -387
- package/templates/skills/business-analyse/steps/step-03a-data.md +16 -16
- package/templates/skills/business-analyse/steps/step-03a1-setup.md +506 -506
- package/templates/skills/business-analyse/steps/step-03a2-analysis.md +252 -252
- package/templates/skills/business-analyse/steps/step-03b-ui.md +425 -425
- package/templates/skills/business-analyse/steps/step-03c-compile.md +611 -611
- package/templates/skills/business-analyse/steps/step-03d-validate.md +783 -783
- package/templates/skills/business-analyse/steps/step-04-consolidation.md +17 -17
- package/templates/skills/business-analyse/steps/step-04a-collect.md +415 -415
- package/templates/skills/business-analyse/steps/step-04b-analyze.md +163 -163
- package/templates/skills/business-analyse/steps/step-04c-decide.md +186 -186
- package/templates/skills/business-analyse/steps/step-05a-handoff.md +840 -840
- package/templates/skills/business-analyse/steps/step-05b-deploy.md +522 -522
- package/templates/skills/business-analyse/steps/step-05c-ralph-readiness.md +703 -703
- package/templates/skills/business-analyse/steps/step-06-review.md +278 -278
- package/templates/skills/business-analyse/templates/tpl-frd.md +168 -168
- package/templates/skills/business-analyse/templates/tpl-handoff.md +186 -186
- package/templates/skills/business-analyse/templates/tpl-launch-displays.md +59 -59
- package/templates/skills/business-analyse/templates/tpl-progress.md +172 -172
- package/templates/skills/business-analyse/templates-frd.md +476 -476
- package/templates/skills/business-analyse/templates-react.md +574 -574
- package/templates/skills/cc-agent/SKILL.md +129 -129
- package/templates/skills/cc-agent/references/agent-behavior-patterns.md +95 -95
- package/templates/skills/cc-agent/references/agent-frontmatter.md +213 -213
- package/templates/skills/cc-agent/references/permission-modes.md +102 -102
- package/templates/skills/cc-agent/references/tools-reference.md +144 -144
- package/templates/skills/cc-agent/steps/step-00-init.md +134 -134
- package/templates/skills/cc-agent/steps/step-01-design.md +186 -186
- package/templates/skills/cc-agent/steps/step-02-generate.md +131 -131
- package/templates/skills/cc-agent/steps/step-03-validate.md +130 -130
- package/templates/skills/cc-agent/templates/agent-categorized.md +67 -67
- package/templates/skills/cc-agent/templates/agent-standalone.md +56 -56
- package/templates/skills/cc-agent/templates/agent-with-skills.md +94 -94
- package/templates/skills/cc-audit/SKILL.md +108 -108
- package/templates/skills/cc-audit/references/agent-checklist.md +91 -91
- package/templates/skills/cc-audit/references/hook-checklist.md +110 -110
- package/templates/skills/cc-audit/references/skill-checklist.md +70 -70
- package/templates/skills/cc-audit/steps/step-00-init.md +98 -98
- package/templates/skills/cc-audit/steps/step-01-scan.md +142 -142
- package/templates/skills/cc-audit/steps/step-02-analyze.md +158 -158
- package/templates/skills/cc-audit/steps/step-03-report.md +142 -142
- package/templates/skills/cc-skill/SKILL.md +134 -134
- package/templates/skills/cc-skill/references/best-practices.md +167 -167
- package/templates/skills/cc-skill/references/frontmatter-reference.md +182 -182
- package/templates/skills/cc-skill/references/skill-patterns.md +199 -199
- package/templates/skills/cc-skill/steps/step-00-init.md +119 -119
- package/templates/skills/cc-skill/steps/step-01-design.md +199 -199
- package/templates/skills/cc-skill/steps/step-02-generate.md +145 -145
- package/templates/skills/cc-skill/steps/step-03-steps.md +151 -151
- package/templates/skills/cc-skill/steps/step-04-validate.md +124 -124
- package/templates/skills/cc-skill/templates/skill-forked.md +85 -85
- package/templates/skills/cc-skill/templates/skill-progressive.md +102 -102
- package/templates/skills/cc-skill/templates/skill-simple.md +75 -75
- package/templates/skills/cc-skill/templates/step-template.md +82 -82
- package/templates/skills/check-version/SKILL.md +196 -196
- package/templates/skills/controller/SKILL.md +162 -162
- package/templates/skills/controller/postman-templates.md +614 -614
- package/templates/skills/controller/references/controller-code-templates.md +159 -159
- package/templates/skills/controller/references/mcp-scaffold-workflow.md +209 -209
- package/templates/skills/controller/references/permission-sync-templates.md +149 -149
- package/templates/skills/controller/steps/step-00-init.md +193 -191
- package/templates/skills/controller/steps/step-01-analyze.md +146 -146
- package/templates/skills/controller/steps/step-02-plan.md +176 -176
- package/templates/skills/controller/steps/step-03-generate.md +189 -189
- package/templates/skills/controller/steps/step-04-perms.md +80 -80
- package/templates/skills/controller/steps/step-05-validate.md +107 -107
- package/templates/skills/controller/templates.md +1555 -1555
- package/templates/skills/debug/SKILL.md +70 -70
- package/templates/skills/debug/references/team-protocol.md +232 -232
- package/templates/skills/debug/steps/step-00-init.md +57 -57
- package/templates/skills/debug/steps/step-01-analyze.md +219 -219
- package/templates/skills/debug/steps/step-02-resolve.md +85 -85
- package/templates/skills/documentation/SKILL.md +132 -132
- package/templates/skills/documentation/data-schema.md +227 -227
- package/templates/skills/documentation/steps/step-00-init.md +70 -70
- package/templates/skills/documentation/steps/step-01-scan.md +113 -113
- package/templates/skills/documentation/steps/step-02-generate.md +231 -231
- package/templates/skills/documentation/steps/step-03-validate.md +251 -238
- package/templates/skills/documentation/templates.md +662 -663
- package/templates/skills/efcore/SKILL.md +167 -167
- package/templates/skills/efcore/references/both-contexts.md +32 -32
- package/templates/skills/efcore/references/database-operations.md +67 -67
- package/templates/skills/efcore/references/destructive-operations.md +38 -38
- package/templates/skills/efcore/references/reset-operations.md +81 -81
- package/templates/skills/efcore/references/seed-methods.md +86 -86
- package/templates/skills/efcore/references/shared-init-functions.md +250 -250
- package/templates/skills/efcore/references/sql-objects-injection.md +61 -61
- package/templates/skills/efcore/references/troubleshooting.md +81 -81
- package/templates/skills/efcore/references/zero-downtime-patterns.md +227 -227
- package/templates/skills/efcore/steps/db/step-deploy.md +217 -217
- package/templates/skills/efcore/steps/db/step-reset.md +186 -186
- package/templates/skills/efcore/steps/db/step-seed.md +166 -166
- package/templates/skills/efcore/steps/db/step-status.md +173 -173
- package/templates/skills/efcore/steps/migration/step-00-init.md +102 -102
- package/templates/skills/efcore/steps/migration/step-01-check.md +164 -164
- package/templates/skills/efcore/steps/migration/step-02-create.md +160 -160
- package/templates/skills/efcore/steps/migration/step-03-validate.md +168 -168
- package/templates/skills/efcore/steps/rebase-snapshot/step-00-init.md +173 -173
- package/templates/skills/efcore/steps/rebase-snapshot/step-01-backup.md +100 -100
- package/templates/skills/efcore/steps/rebase-snapshot/step-02-fetch.md +115 -115
- package/templates/skills/efcore/steps/rebase-snapshot/step-03-create.md +112 -112
- package/templates/skills/efcore/steps/rebase-snapshot/step-04-validate.md +157 -157
- package/templates/skills/efcore/steps/shared/step-00-init.md +131 -131
- package/templates/skills/efcore/steps/squash/step-00-init.md +141 -141
- package/templates/skills/efcore/steps/squash/step-01-backup.md +120 -120
- package/templates/skills/efcore/steps/squash/step-02-fetch.md +168 -168
- package/templates/skills/efcore/steps/squash/step-03-create.md +184 -184
- package/templates/skills/efcore/steps/squash/step-04-validate.md +174 -174
- package/templates/skills/explore/SKILL.md +98 -98
- package/templates/skills/feature-full/SKILL.md +111 -111
- package/templates/skills/feature-full/steps/step-00-init.md +57 -57
- package/templates/skills/feature-full/steps/step-01-implementation.md +120 -120
- package/templates/skills/gitflow/SKILL.md +377 -377
- package/templates/skills/gitflow/_shared.md +620 -620
- package/templates/skills/gitflow/phases/abort.md +189 -189
- package/templates/skills/gitflow/phases/cleanup.md +234 -234
- package/templates/skills/gitflow/phases/status.md +192 -192
- package/templates/skills/gitflow/references/commit-message-generation.md +58 -58
- package/templates/skills/gitflow/references/commit-migration-validation.md +49 -49
- package/templates/skills/gitflow/references/finish-cleanup.md +55 -55
- package/templates/skills/gitflow/references/finish-version-bumping.md +45 -45
- package/templates/skills/gitflow/references/init-config-template.md +135 -135
- package/templates/skills/gitflow/references/init-environment-detection.md +41 -41
- package/templates/skills/gitflow/references/init-name-normalization.md +103 -103
- package/templates/skills/gitflow/references/init-questions.md +185 -185
- package/templates/skills/gitflow/references/init-structure-creation.md +75 -75
- package/templates/skills/gitflow/references/init-version-detection.md +21 -21
- package/templates/skills/gitflow/references/init-workspace-detection.md +43 -43
- package/templates/skills/gitflow/references/merge-ci-status.md +36 -36
- package/templates/skills/gitflow/references/merge-execution.md +62 -62
- package/templates/skills/gitflow/references/merge-pr-context.md +76 -76
- package/templates/skills/gitflow/references/plan-template.md +69 -69
- package/templates/skills/gitflow/references/pr-build-checks.md +60 -60
- package/templates/skills/gitflow/references/pr-generation.md +58 -58
- package/templates/skills/gitflow/references/start-branch-normalization.md +28 -28
- package/templates/skills/gitflow/references/start-efcore-preflight.md +70 -70
- package/templates/skills/gitflow/references/start-local-config.md +113 -113
- package/templates/skills/gitflow/references/start-worktree-creation.md +50 -50
- package/templates/skills/gitflow/references/sync-push-verify.md +44 -44
- package/templates/skills/gitflow/references/sync-rebase-conflicts.md +38 -38
- package/templates/skills/gitflow/steps/step-commit.md +199 -199
- package/templates/skills/gitflow/steps/step-finish.md +147 -147
- package/templates/skills/gitflow/steps/step-init.md +190 -190
- package/templates/skills/gitflow/steps/step-merge.md +85 -85
- package/templates/skills/gitflow/steps/step-plan.md +151 -151
- package/templates/skills/gitflow/steps/step-pr.md +199 -199
- package/templates/skills/gitflow/steps/step-start.md +195 -195
- package/templates/skills/gitflow/steps/step-sync.md +161 -161
- package/templates/skills/gitflow/templates/config.json +72 -72
- package/templates/skills/mcp/SKILL.md +62 -62
- package/templates/skills/mcp/steps/step-01-healthcheck.md +108 -108
- package/templates/skills/mcp/steps/step-02-tools.md +73 -73
- package/templates/skills/notification/SKILL.md +173 -173
- package/templates/skills/quick-search/SKILL.md +99 -99
- package/templates/skills/ralph-loop/SKILL.md +234 -234
- package/templates/skills/ralph-loop/references/category-completeness.md +185 -185
- package/templates/skills/ralph-loop/references/category-rules.md +96 -96
- package/templates/skills/ralph-loop/references/compact-loop.md +300 -300
- package/templates/skills/ralph-loop/references/init-resume-recovery.md +127 -127
- package/templates/skills/ralph-loop/references/module-transition.md +151 -151
- package/templates/skills/ralph-loop/references/multi-module-queue.md +171 -171
- package/templates/skills/ralph-loop/references/parallel-execution.md +246 -246
- package/templates/skills/ralph-loop/references/section-splitting.md +439 -439
- package/templates/skills/ralph-loop/references/task-transform-legacy.md +256 -256
- package/templates/skills/ralph-loop/references/team-orchestration.md +547 -547
- package/templates/skills/ralph-loop/steps/step-00-init.md +150 -150
- package/templates/skills/ralph-loop/steps/step-01-task.md +174 -174
- package/templates/skills/ralph-loop/steps/step-02-execute.md +177 -177
- package/templates/skills/ralph-loop/steps/step-03-commit.md +92 -92
- package/templates/skills/ralph-loop/steps/step-04-check.md +207 -207
- package/templates/skills/ralph-loop/steps/step-05-report.md +175 -175
- package/templates/skills/refactor/SKILL.md +56 -56
- package/templates/skills/refactor/steps/step-01-discover.md +60 -60
- package/templates/skills/refactor/steps/step-02-execute.md +67 -67
- package/templates/skills/review-code/SKILL.md +94 -94
- package/templates/skills/review-code/references/clean-code-principles.md +292 -292
- package/templates/skills/review-code/references/code-quality-metrics.md +174 -174
- package/templates/skills/review-code/references/feedback-patterns.md +149 -149
- package/templates/skills/review-code/references/owasp-api-top10.md +243 -243
- package/templates/skills/review-code/references/security-checklist.md +212 -212
- package/templates/skills/review-code/steps/step-01-smartstack.md +96 -96
- package/templates/skills/review-code/steps/step-02-detailed-review.md +80 -80
- package/templates/skills/review-code/steps/step-03-react.md +44 -44
- package/templates/skills/ui-components/SKILL.md +137 -137
- package/templates/skills/ui-components/accessibility.md +170 -170
- package/templates/skills/ui-components/patterns/dashboard-chart.md +327 -327
- package/templates/skills/ui-components/patterns/data-table.md +39 -39
- package/templates/skills/ui-components/patterns/entity-card.md +77 -77
- package/templates/skills/ui-components/patterns/grid-layout.md +91 -91
- package/templates/skills/ui-components/patterns/kanban.md +43 -43
- package/templates/skills/ui-components/responsive-guidelines.md +278 -278
- package/templates/skills/ui-components/style-guide.md +113 -113
- package/templates/skills/utils/SKILL.md +44 -44
- package/templates/skills/utils/subcommands/test-web-config.md +152 -152
- package/templates/skills/utils/subcommands/test-web.md +123 -123
- package/templates/skills/validate/SKILL.md +181 -181
- package/templates/skills/validate-feature/SKILL.md +101 -101
- package/templates/skills/validate-feature/references/api-smoke-tests.md +140 -140
- package/templates/skills/validate-feature/references/db-validation-checks.md +180 -180
- package/templates/skills/validate-feature/steps/step-00-dependencies.md +121 -121
- package/templates/skills/validate-feature/steps/step-01-compile.md +39 -39
- package/templates/skills/validate-feature/steps/step-02-unit-tests.md +45 -45
- package/templates/skills/validate-feature/steps/step-03-integration-tests.md +53 -53
- package/templates/skills/validate-feature/steps/step-04-api-smoke.md +94 -94
- package/templates/skills/validate-feature/steps/step-05-db-validation.md +149 -149
- package/templates/skills/workflow/SKILL.md +127 -127
- package/templates/skills/workflow/steps/step-00-init.md +57 -57
- package/templates/skills/workflow/steps/step-01-implementation.md +84 -84
- package/templates/test-web/api-health.json +38 -38
- package/templates/test-web/minimal.json +19 -19
- package/templates/test-web/npm-package.json +46 -46
- package/templates/test-web/seo-check.json +54 -54
|
@@ -1,516 +1,516 @@
|
|
|
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="resetToEmbedded()" title="Reinitialiser depuis les donnees d'origine (supprime les modifications locales)">Reset</button>
|
|
24
|
-
<button class="btn btn-sm" onclick="saveToLocalStorage()" title="Sauvegarder les modifications dans le navigateur">Sauvegarder</button>
|
|
25
|
-
<button class="btn btn-sm btn-review" onclick="saveReviewJSON()" title="Sauvegarder les corrections pour creer une nouvelle version">Sauvegarder corrections</button>
|
|
26
|
-
<button class="btn btn-sm btn-primary" onclick="exportJSON()" title="Exporter les donnees au format JSON pour l'extraction">Exporter JSON</button>
|
|
27
|
-
<button class="btn btn-sm review-toggle-btn" id="reviewToggleBtn" onclick="toggleReviewPanel()" title="Ouvrir/fermer le panneau de review">
|
|
28
|
-
Review
|
|
29
|
-
<span class="review-badge hidden" id="reviewBadge">0</span>
|
|
30
|
-
</button>
|
|
31
|
-
</div>
|
|
32
|
-
</header>
|
|
33
|
-
|
|
34
|
-
<div class="body" id="appBody">
|
|
35
|
-
<!-- ============================================
|
|
36
|
-
SIDEBAR - Navigation hierarchique
|
|
37
|
-
============================================ -->
|
|
38
|
-
<aside class="sidebar">
|
|
39
|
-
<!-- Application Name -->
|
|
40
|
-
<div class="sidebar-header">
|
|
41
|
-
<span class="sidebar-app-name" id="sidebarAppName">{{APPLICATION_NAME}}</span>
|
|
42
|
-
</div>
|
|
43
|
-
<!-- Dynamic Tree Navigation -->
|
|
44
|
-
<div id="sidebarNav">
|
|
45
|
-
<!-- Populated by buildNavTree() -->
|
|
46
|
-
</div>
|
|
47
|
-
</aside>
|
|
48
|
-
|
|
49
|
-
<!-- ============================================
|
|
50
|
-
MAIN CONTENT
|
|
51
|
-
============================================ -->
|
|
52
|
-
<main class="main" id="mainContent">
|
|
53
|
-
|
|
54
|
-
<!-- SECTION: Contexte (merged: problem + current + vision) -->
|
|
55
|
-
<div class="section" id="cadrage-context">
|
|
56
|
-
<h2 class="section-title">Contexte du projet</h2>
|
|
57
|
-
<p class="section-subtitle">Vue synthetique du besoin : probleme, situation actuelle et objectif vise.</p>
|
|
58
|
-
|
|
59
|
-
<div style="display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;">
|
|
60
|
-
<div class="card" style="border-left:3px solid #f87171;">
|
|
61
|
-
<div class="card-label" style="color:#f87171;">Probleme identifie</div>
|
|
62
|
-
<div class="editable" contenteditable="true" data-field="context.problem" data-placeholder="Quel probleme ce projet doit-il resoudre ?"></div>
|
|
63
|
-
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
64
|
-
<strong>Declencheur :</strong>
|
|
65
|
-
<div class="editable" contenteditable="true" data-field="context.trigger" data-placeholder="Evenement declencheur" style="display:inline;"></div>
|
|
66
|
-
</div>
|
|
67
|
-
</div>
|
|
68
|
-
|
|
69
|
-
<div class="card" style="border-left:3px solid #facc15;">
|
|
70
|
-
<div class="card-label" style="color:#facc15;">Aujourd'hui</div>
|
|
71
|
-
<div class="editable" contenteditable="true" data-field="context.currentSituation" data-placeholder="Comment les choses fonctionnent actuellement ?"></div>
|
|
72
|
-
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
73
|
-
<strong>Points douleur :</strong>
|
|
74
|
-
<div class="editable" contenteditable="true" data-field="context.painPoints" data-placeholder="Problemes recurrents" style="display:inline;"></div>
|
|
75
|
-
</div>
|
|
76
|
-
</div>
|
|
77
|
-
|
|
78
|
-
<div class="card" style="border-left:3px solid #4ade80;">
|
|
79
|
-
<div class="card-label" style="color:#4ade80;">Objectif</div>
|
|
80
|
-
<div class="editable" contenteditable="true" data-field="context.desiredSituation" data-placeholder="Que doit permettre le systeme cible ?"></div>
|
|
81
|
-
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
82
|
-
<strong>Criteres :</strong>
|
|
83
|
-
<div class="editable" contenteditable="true" data-field="context.acceptanceCriteria" data-placeholder="Criteres de succes" style="display:inline;"></div>
|
|
84
|
-
</div>
|
|
85
|
-
</div>
|
|
86
|
-
</div>
|
|
87
|
-
</div>
|
|
88
|
-
|
|
89
|
-
<!-- SECTION: Parties prenantes -->
|
|
90
|
-
<div class="section" id="cadrage-stakeholders" style="display:none;">
|
|
91
|
-
<h2 class="section-title">Parties prenantes</h2>
|
|
92
|
-
<p class="section-subtitle">Toutes les personnes concernees par ce projet et leurs besoins.</p>
|
|
93
|
-
|
|
94
|
-
<div class="stakeholder-grid" id="stakeholderGrid">
|
|
95
|
-
<!-- Populated dynamically -->
|
|
96
|
-
</div>
|
|
97
|
-
|
|
98
|
-
<button class="add-btn" onclick="toggleForm('addStakeholderForm')">+ Ajouter un profil utilisateur</button>
|
|
99
|
-
|
|
100
|
-
<div class="inline-form" id="addStakeholderForm">
|
|
101
|
-
<div class="inline-form-title">Nouveau profil utilisateur</div>
|
|
102
|
-
<div class="form-group">
|
|
103
|
-
<label class="form-label">Titre du profil (exemple : Responsable de production)</label>
|
|
104
|
-
<input type="text" class="form-input" id="sh-role" placeholder="Titre ou description du profil">
|
|
105
|
-
</div>
|
|
106
|
-
<div class="form-group">
|
|
107
|
-
<label class="form-label">Fonction dans l'entreprise</label>
|
|
108
|
-
<input type="text" class="form-input" id="sh-function" placeholder="Ce qu'il fait dans l'organisation">
|
|
109
|
-
</div>
|
|
110
|
-
<div class="form-group">
|
|
111
|
-
<label class="form-label">Taches principales (une par ligne)</label>
|
|
112
|
-
<textarea class="form-textarea" id="sh-tasks" placeholder="Tache 1 Tache 2 Tache 3"></textarea>
|
|
113
|
-
</div>
|
|
114
|
-
<div class="form-row">
|
|
115
|
-
<div class="form-group">
|
|
116
|
-
<label class="form-label">Frequence d'utilisation</label>
|
|
117
|
-
<select class="form-select" id="sh-frequency">
|
|
118
|
-
<option value="daily">Quotidienne</option>
|
|
119
|
-
<option value="weekly">Hebdomadaire</option>
|
|
120
|
-
<option value="monthly">Mensuelle</option>
|
|
121
|
-
<option value="occasional">Occasionnelle</option>
|
|
122
|
-
</select>
|
|
123
|
-
</div>
|
|
124
|
-
<div class="form-group">
|
|
125
|
-
<label class="form-label">Niveau d'acces</label>
|
|
126
|
-
<select class="form-select" id="sh-access">
|
|
127
|
-
<option value="admin">Administration complete</option>
|
|
128
|
-
<option value="manager">Supervision et validation</option>
|
|
129
|
-
<option value="contributor">Saisie et modification</option>
|
|
130
|
-
<option value="viewer">Consultation seule</option>
|
|
131
|
-
</select>
|
|
132
|
-
</div>
|
|
133
|
-
</div>
|
|
134
|
-
<div class="form-group">
|
|
135
|
-
<label class="form-label">Frustrations actuelles</label>
|
|
136
|
-
<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>
|
|
137
|
-
</div>
|
|
138
|
-
<div class="form-actions">
|
|
139
|
-
<button class="btn" onclick="toggleForm('addStakeholderForm')">Annuler</button>
|
|
140
|
-
<button class="btn btn-primary" onclick="addStakeholder()">Ajouter ce profil</button>
|
|
141
|
-
</div>
|
|
142
|
-
</div>
|
|
143
|
-
</div>
|
|
144
|
-
|
|
145
|
-
<!-- SECTION: Perimetre fonctionnel -->
|
|
146
|
-
<div class="section" id="cadrage-scope" style="display:none;">
|
|
147
|
-
<h2 class="section-title">Perimetre fonctionnel</h2>
|
|
148
|
-
<p class="section-subtitle">Ce que le systeme doit faire et ne pas faire, par ordre de priorite.</p>
|
|
149
|
-
|
|
150
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">
|
|
151
|
-
<span style="color: #f87171;">■</span> Fonctionnalites indispensables
|
|
152
|
-
</h3>
|
|
153
|
-
<div id="scopeVital" class="uc-list"></div>
|
|
154
|
-
<button class="add-btn" onclick="toggleForm('addScopeForm-vital')">+ Ajouter une fonctionnalite indispensable</button>
|
|
155
|
-
<div class="inline-form" id="addScopeForm-vital">
|
|
156
|
-
<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>
|
|
157
|
-
<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>
|
|
158
|
-
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-vital')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('vital')">Ajouter</button></div>
|
|
159
|
-
</div>
|
|
160
|
-
|
|
161
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
162
|
-
<span style="color: #facc15;">■</span> Fonctionnalites importantes
|
|
163
|
-
</h3>
|
|
164
|
-
<div id="scopeImportant" class="uc-list"></div>
|
|
165
|
-
<button class="add-btn" onclick="toggleForm('addScopeForm-important')">+ Ajouter une fonctionnalite importante</button>
|
|
166
|
-
<div class="inline-form" id="addScopeForm-important">
|
|
167
|
-
<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>
|
|
168
|
-
<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>
|
|
169
|
-
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-important')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('important')">Ajouter</button></div>
|
|
170
|
-
</div>
|
|
171
|
-
|
|
172
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
173
|
-
<span style="color: #4ade80;">■</span> Fonctionnalites optionnelles
|
|
174
|
-
</h3>
|
|
175
|
-
<div id="scopeOptional" class="uc-list"></div>
|
|
176
|
-
<button class="add-btn" onclick="toggleForm('addScopeForm-optional')">+ Ajouter une fonctionnalite optionnelle</button>
|
|
177
|
-
<div class="inline-form" id="addScopeForm-optional">
|
|
178
|
-
<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>
|
|
179
|
-
<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>
|
|
180
|
-
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-optional')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('optional')">Ajouter</button></div>
|
|
181
|
-
</div>
|
|
182
|
-
|
|
183
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
184
|
-
<span style="color: #94a3b8;">■</span> Hors perimetre
|
|
185
|
-
</h3>
|
|
186
|
-
<div id="scopeExcluded" class="uc-list"></div>
|
|
187
|
-
<button class="add-btn" onclick="toggleForm('addScopeForm-excluded')">+ Ajouter une exclusion</button>
|
|
188
|
-
<div class="inline-form" id="addScopeForm-excluded">
|
|
189
|
-
<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>
|
|
190
|
-
<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>
|
|
191
|
-
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-excluded')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('excluded')">Ajouter</button></div>
|
|
192
|
-
</div>
|
|
193
|
-
</div>
|
|
194
|
-
|
|
195
|
-
<!-- SECTION: Risques et hypotheses -->
|
|
196
|
-
<div class="section" id="cadrage-risks" style="display:none;">
|
|
197
|
-
<h2 class="section-title">Risques et hypotheses</h2>
|
|
198
|
-
<p class="section-subtitle">Ce qui pourrait mal tourner et les certitudes non verifiees.</p>
|
|
199
|
-
|
|
200
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">Risques identifies</h3>
|
|
201
|
-
<div id="risksList"></div>
|
|
202
|
-
<button class="add-btn" onclick="toggleForm('addRiskForm')">+ Ajouter un risque</button>
|
|
203
|
-
|
|
204
|
-
<div class="inline-form" id="addRiskForm">
|
|
205
|
-
<div class="inline-form-title">Nouveau risque</div>
|
|
206
|
-
<div class="form-group">
|
|
207
|
-
<label class="form-label">Description du risque</label>
|
|
208
|
-
<input type="text" class="form-input" id="risk-desc" placeholder="Qu'est-ce qui pourrait mal tourner ?">
|
|
209
|
-
</div>
|
|
210
|
-
<div class="form-row">
|
|
211
|
-
<div class="form-group">
|
|
212
|
-
<label class="form-label">Probabilite</label>
|
|
213
|
-
<select class="form-select" id="risk-probability">
|
|
214
|
-
<option value="high">Forte</option>
|
|
215
|
-
<option value="medium">Moyenne</option>
|
|
216
|
-
<option value="low">Faible</option>
|
|
217
|
-
</select>
|
|
218
|
-
</div>
|
|
219
|
-
<div class="form-group">
|
|
220
|
-
<label class="form-label">Impact</label>
|
|
221
|
-
<select class="form-select" id="risk-impact">
|
|
222
|
-
<option value="high">Grave</option>
|
|
223
|
-
<option value="medium">Moyen</option>
|
|
224
|
-
<option value="low">Faible</option>
|
|
225
|
-
</select>
|
|
226
|
-
</div>
|
|
227
|
-
</div>
|
|
228
|
-
<div class="form-group">
|
|
229
|
-
<label class="form-label">Mesure de prevention ou de reduction</label>
|
|
230
|
-
<textarea class="form-textarea" id="risk-mitigation" placeholder="Comment prevenir ou reduire ce risque ?"></textarea>
|
|
231
|
-
</div>
|
|
232
|
-
<div class="form-actions">
|
|
233
|
-
<button class="btn" onclick="toggleForm('addRiskForm')">Annuler</button>
|
|
234
|
-
<button class="btn btn-primary" onclick="addRisk()">Ajouter ce risque</button>
|
|
235
|
-
</div>
|
|
236
|
-
</div>
|
|
237
|
-
|
|
238
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Hypotheses a verifier</h3>
|
|
239
|
-
<div class="card">
|
|
240
|
-
<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>
|
|
241
|
-
</div>
|
|
242
|
-
</div>
|
|
243
|
-
|
|
244
|
-
<!-- SECTION: Criteres de reussite -->
|
|
245
|
-
<div class="section" id="cadrage-success" style="display:none;">
|
|
246
|
-
<h2 class="section-title">Criteres de reussite</h2>
|
|
247
|
-
<p class="section-subtitle">Comment mesurer objectivement que le projet est un succes.</p>
|
|
248
|
-
|
|
249
|
-
<div class="card">
|
|
250
|
-
<div class="card-label">Definition du succes</div>
|
|
251
|
-
<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>
|
|
252
|
-
</div>
|
|
253
|
-
|
|
254
|
-
<div class="card" data-vibe-hide>
|
|
255
|
-
<div class="card-label">Objectifs mesurables</div>
|
|
256
|
-
<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>
|
|
257
|
-
</div>
|
|
258
|
-
|
|
259
|
-
<div class="card" data-vibe-hide>
|
|
260
|
-
<div class="card-label">Delai d'evaluation</div>
|
|
261
|
-
<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>
|
|
262
|
-
</div>
|
|
263
|
-
|
|
264
|
-
<div class="card" data-vibe-hide>
|
|
265
|
-
<div class="card-label">Conditions minimales de mise en service</div>
|
|
266
|
-
<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>
|
|
267
|
-
</div>
|
|
268
|
-
|
|
269
|
-
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Criteres d'acceptation</h3>
|
|
270
|
-
<p style="font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem;">Criteres concrets et mesurables pour valider le succes du projet.</p>
|
|
271
|
-
<div id="criteriaList" class="uc-list"></div>
|
|
272
|
-
<button class="add-btn" onclick="toggleForm('addCriterionForm')">+ Ajouter un critere d'acceptation</button>
|
|
273
|
-
<div class="inline-form" id="addCriterionForm">
|
|
274
|
-
<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>
|
|
275
|
-
<div class="form-actions"><button class="btn" onclick="toggleForm('addCriterionForm')">Annuler</button><button class="btn btn-primary" onclick="addCriterion()">Ajouter</button></div>
|
|
276
|
-
</div>
|
|
277
|
-
</div>
|
|
278
|
-
|
|
279
|
-
<!-- ================================================================
|
|
280
|
-
PHASE 2 : DECOMPOSITION
|
|
281
|
-
================================================================ -->
|
|
282
|
-
|
|
283
|
-
<!-- SECTION: Domaines fonctionnels -->
|
|
284
|
-
<div class="section" id="decomp-modules" style="display:none;">
|
|
285
|
-
<h2 class="section-title">Domaines fonctionnels</h2>
|
|
286
|
-
<p class="section-subtitle">Identifiez les grands domaines de votre application. Chaque domaine regroupe des fonctionnalites coherentes et independantes.</p>
|
|
287
|
-
|
|
288
|
-
<div class="module-grid" id="moduleGrid">
|
|
289
|
-
<!-- Populated dynamically -->
|
|
290
|
-
</div>
|
|
291
|
-
|
|
292
|
-
<button class="add-btn" onclick="toggleForm('addModuleForm')" style="margin-top:1rem;">+ Ajouter un domaine fonctionnel</button>
|
|
293
|
-
|
|
294
|
-
<div class="inline-form" id="addModuleForm">
|
|
295
|
-
<div class="inline-form-title">Nouveau domaine fonctionnel</div>
|
|
296
|
-
<div class="form-group">
|
|
297
|
-
<label class="form-label">Nom du domaine (exemple : Gestion des commandes)</label>
|
|
298
|
-
<input type="text" class="form-input" id="mod-name" placeholder="Nom clair et explicite">
|
|
299
|
-
</div>
|
|
300
|
-
<div class="form-group">
|
|
301
|
-
<label class="form-label">Description en une ou deux phrases</label>
|
|
302
|
-
<textarea class="form-textarea" id="mod-desc" placeholder="A quoi sert ce domaine ? Quel probleme resout-il ?"></textarea>
|
|
303
|
-
</div>
|
|
304
|
-
<div class="form-row">
|
|
305
|
-
<div class="form-group">
|
|
306
|
-
<label class="form-label">Type de domaine</label>
|
|
307
|
-
<select class="form-select" id="mod-type">
|
|
308
|
-
<option value="data-centric">Gestion de donnees (listes, fiches, formulaires)</option>
|
|
309
|
-
<option value="workflow">Processus metier (etapes, validations, approbations)</option>
|
|
310
|
-
<option value="reporting">Tableaux de bord et rapports</option>
|
|
311
|
-
<option value="integration">Integration avec des systemes externes</option>
|
|
312
|
-
<option value="full-module">Domaine complet (donnees + processus + rapports)</option>
|
|
313
|
-
</select>
|
|
314
|
-
</div>
|
|
315
|
-
<div class="form-group">
|
|
316
|
-
<label class="form-label">Priorite</label>
|
|
317
|
-
<select class="form-select" id="mod-priority">
|
|
318
|
-
<option value="must">Indispensable</option>
|
|
319
|
-
<option value="should">Important</option>
|
|
320
|
-
<option value="could">Optionnel</option>
|
|
321
|
-
</select>
|
|
322
|
-
</div>
|
|
323
|
-
</div>
|
|
324
|
-
<div class="form-group">
|
|
325
|
-
<label class="form-label">Principales donnees gerees (une par ligne)</label>
|
|
326
|
-
<textarea class="form-textarea" id="mod-entities" placeholder="Commande Ligne de commande Facture"></textarea>
|
|
327
|
-
</div>
|
|
328
|
-
<div class="form-actions">
|
|
329
|
-
<button class="btn" onclick="toggleForm('addModuleForm')">Annuler</button>
|
|
330
|
-
<button class="btn btn-primary" onclick="addModule()">Ajouter ce domaine</button>
|
|
331
|
-
</div>
|
|
332
|
-
</div>
|
|
333
|
-
</div>
|
|
334
|
-
|
|
335
|
-
<!-- SECTION: Dependances -->
|
|
336
|
-
<div class="section" id="decomp-dependencies" style="display:none;">
|
|
337
|
-
<h2 class="section-title">Dependances entre domaines</h2>
|
|
338
|
-
<p class="section-subtitle">Indiquez quels domaines dependent d'autres domaines. Par exemple, les Commandes dependent des Clients et des Produits.</p>
|
|
339
|
-
|
|
340
|
-
<div id="depGraphContainer">
|
|
341
|
-
<div class="dep-graph" id="depGraph">
|
|
342
|
-
<p style="color:var(--text-muted);text-align:center;padding:2rem;">Ajoutez des domaines fonctionnels pour visualiser les dependances.</p>
|
|
343
|
-
</div>
|
|
344
|
-
</div>
|
|
345
|
-
|
|
346
|
-
<div style="margin-top:1.5rem;">
|
|
347
|
-
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ajouter une dependance</h3>
|
|
348
|
-
<div class="form-row">
|
|
349
|
-
<div class="form-group">
|
|
350
|
-
<label class="form-label">Ce domaine...</label>
|
|
351
|
-
<select class="form-select" id="dep-from"></select>
|
|
352
|
-
</div>
|
|
353
|
-
<div class="form-group">
|
|
354
|
-
<label class="form-label">...depend de</label>
|
|
355
|
-
<select class="form-select" id="dep-to"></select>
|
|
356
|
-
</div>
|
|
357
|
-
</div>
|
|
358
|
-
<div class="form-group">
|
|
359
|
-
<label class="form-label">Nature de la dependance</label>
|
|
360
|
-
<input type="text" class="form-input" id="dep-desc" placeholder="Exemple : La commande reference un client existant">
|
|
361
|
-
</div>
|
|
362
|
-
<button class="btn btn-primary" onclick="addDependency()" style="margin-top:0.5rem;">Ajouter cette dependance</button>
|
|
363
|
-
</div>
|
|
364
|
-
|
|
365
|
-
<div id="depList" style="margin-top:1.5rem;"></div>
|
|
366
|
-
|
|
367
|
-
<div style="margin-top:2rem;">
|
|
368
|
-
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ordre de traitement propose</h3>
|
|
369
|
-
<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>
|
|
370
|
-
<div id="processingOrder" class="process-flow"></div>
|
|
371
|
-
</div>
|
|
372
|
-
</div>
|
|
373
|
-
|
|
374
|
-
<!-- ================================================================
|
|
375
|
-
PHASE 3 : SPECIFICATION PAR MODULE
|
|
376
|
-
================================================================ -->
|
|
377
|
-
|
|
378
|
-
<!-- Container dynamique pour les specs de chaque module -->
|
|
379
|
-
<div id="moduleSpecContainer">
|
|
380
|
-
<!-- Generated dynamically by renderModuleSpec() -->
|
|
381
|
-
</div>
|
|
382
|
-
|
|
383
|
-
<!-- ================================================================
|
|
384
|
-
PHASE 4 : CONSOLIDATION
|
|
385
|
-
================================================================ -->
|
|
386
|
-
|
|
387
|
-
<!-- SECTION: Modele de donnees -->
|
|
388
|
-
<div class="section" id="consol-datamodel" style="display:none;">
|
|
389
|
-
<h2 class="section-title">Modele de donnees</h2>
|
|
390
|
-
<p class="section-subtitle">Vue d'ensemble de toutes les entites metier, leurs attributs et leurs relations entre domaines.</p>
|
|
391
|
-
<div id="dataModelContainer">
|
|
392
|
-
<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>
|
|
393
|
-
</div>
|
|
394
|
-
</div>
|
|
395
|
-
|
|
396
|
-
<!-- SECTION: Interactions cross-module -->
|
|
397
|
-
<div class="section" id="consol-interactions" style="display:none;">
|
|
398
|
-
<h2 class="section-title">Interactions entre domaines</h2>
|
|
399
|
-
<p class="section-subtitle">Vue d'ensemble de la facon dont les domaines communiquent et partagent des donnees.</p>
|
|
400
|
-
<div id="consolInteractions">
|
|
401
|
-
<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>
|
|
402
|
-
</div>
|
|
403
|
-
</div>
|
|
404
|
-
|
|
405
|
-
<!-- SECTION: Coherence des acces -->
|
|
406
|
-
<div class="section" id="consol-permissions" style="display:none;">
|
|
407
|
-
<h2 class="section-title">Coherence des droits d'acces</h2>
|
|
408
|
-
<p class="section-subtitle">Verification que les profils utilisateurs ont des droits coherents dans tous les domaines.</p>
|
|
409
|
-
<div id="consolPermissions">
|
|
410
|
-
<p style="color:var(--text-muted);text-align:center;padding:2rem;">La coherence sera verifiee quand les permissions de chaque domaine seront definies.</p>
|
|
411
|
-
</div>
|
|
412
|
-
</div>
|
|
413
|
-
|
|
414
|
-
<!-- SECTION: Parcours bout en bout -->
|
|
415
|
-
<div class="section" id="consol-flows" style="display:none;">
|
|
416
|
-
<h2 class="section-title">Parcours bout en bout</h2>
|
|
417
|
-
<p class="section-subtitle">Les processus metier qui traversent plusieurs domaines, de bout en bout.</p>
|
|
418
|
-
|
|
419
|
-
<div id="e2eFlowsList"></div>
|
|
420
|
-
|
|
421
|
-
<button class="add-btn" onclick="toggleForm('addFlowForm')">+ Ajouter un parcours</button>
|
|
422
|
-
|
|
423
|
-
<div class="inline-form" id="addFlowForm">
|
|
424
|
-
<div class="inline-form-title">Nouveau parcours bout en bout</div>
|
|
425
|
-
<div class="form-group">
|
|
426
|
-
<label class="form-label">Nom du parcours (exemple : De la commande a la facture)</label>
|
|
427
|
-
<input type="text" class="form-input" id="flow-name" placeholder="Nom descriptif du parcours">
|
|
428
|
-
</div>
|
|
429
|
-
<div class="form-group">
|
|
430
|
-
<label class="form-label">Etapes du parcours (une par ligne : Domaine - Action)</label>
|
|
431
|
-
<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>
|
|
432
|
-
</div>
|
|
433
|
-
<div class="form-group">
|
|
434
|
-
<label class="form-label">Qui intervient dans ce parcours ?</label>
|
|
435
|
-
<input type="text" class="form-input" id="flow-actors" placeholder="Exemple : Contributeur (creation), Responsable (validation)">
|
|
436
|
-
</div>
|
|
437
|
-
<div class="form-actions">
|
|
438
|
-
<button class="btn" onclick="toggleForm('addFlowForm')">Annuler</button>
|
|
439
|
-
<button class="btn btn-primary" onclick="addE2EFlow()">Ajouter ce parcours</button>
|
|
440
|
-
</div>
|
|
441
|
-
</div>
|
|
442
|
-
</div>
|
|
443
|
-
|
|
444
|
-
<!-- ================================================================
|
|
445
|
-
PHASE 5 : SYNTHESE
|
|
446
|
-
================================================================ -->
|
|
447
|
-
|
|
448
|
-
<div class="section" id="handoff-summary" style="display:none;">
|
|
449
|
-
<h2 class="section-title">Synthese de l'analyse</h2>
|
|
450
|
-
<p class="section-subtitle">Vue d'ensemble de toute l'analyse metier, prete pour le developpement.</p>
|
|
451
|
-
|
|
452
|
-
<div class="stat-grid" id="handoffStats">
|
|
453
|
-
<!-- Populated dynamically -->
|
|
454
|
-
</div>
|
|
455
|
-
|
|
456
|
-
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Domaines par ordre de traitement</h3>
|
|
457
|
-
<div id="handoffModuleList"></div>
|
|
458
|
-
|
|
459
|
-
<h3 style="color:var(--text-bright);font-size:1rem;margin:1.5rem 0 0.75rem;">Couverture du besoin initial</h3>
|
|
460
|
-
<div class="card">
|
|
461
|
-
<div class="card-label">Matrice de couverture</div>
|
|
462
|
-
<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>
|
|
463
|
-
<div id="coverageMatrix"></div>
|
|
464
|
-
</div>
|
|
465
|
-
|
|
466
|
-
<div style="margin-top:2rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;text-align:center;">
|
|
467
|
-
<p style="color:var(--text-bright);font-size:1.1rem;font-weight:600;margin-bottom:0.5rem;">Analyse prete pour l'extraction</p>
|
|
468
|
-
<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>
|
|
469
|
-
<button class="btn btn-primary" onclick="exportJSON()" style="font-size:0.9rem;padding:0.6rem 1.5rem;">Exporter l'analyse complete en JSON</button>
|
|
470
|
-
</div>
|
|
471
|
-
</div>
|
|
472
|
-
|
|
473
|
-
</main>
|
|
474
|
-
|
|
475
|
-
<!-- ============================================
|
|
476
|
-
REVIEW PANEL (right sidebar)
|
|
477
|
-
============================================ -->
|
|
478
|
-
<aside class="review-panel" id="reviewPanel">
|
|
479
|
-
<div class="review-panel-header">
|
|
480
|
-
<span class="review-panel-title">Review</span>
|
|
481
|
-
<button class="review-panel-close" onclick="toggleReviewPanel()" title="Fermer">×</button>
|
|
482
|
-
</div>
|
|
483
|
-
<div class="review-filters">
|
|
484
|
-
<button class="review-filter-btn active" onclick="filterReviewComments('all')" data-filter="all">Tous</button>
|
|
485
|
-
<button class="review-filter-btn" onclick="filterReviewComments('to-review')" data-filter="to-review">A revoir</button>
|
|
486
|
-
<button class="review-filter-btn" onclick="filterReviewComments('validated')" data-filter="validated">Valides</button>
|
|
487
|
-
</div>
|
|
488
|
-
<div class="review-comments" id="reviewCommentsList">
|
|
489
|
-
<div class="review-empty">Aucun commentaire pour le moment.</div>
|
|
490
|
-
</div>
|
|
491
|
-
<div class="review-stats" id="reviewStats">
|
|
492
|
-
<div class="review-stat">
|
|
493
|
-
<div class="review-stat-value" id="reviewStatTotal">0</div>
|
|
494
|
-
<div class="review-stat-label">Total</div>
|
|
495
|
-
</div>
|
|
496
|
-
<div class="review-stat">
|
|
497
|
-
<div class="review-stat-value" id="reviewStatToReview">0</div>
|
|
498
|
-
<div class="review-stat-label">A revoir</div>
|
|
499
|
-
</div>
|
|
500
|
-
<div class="review-stat">
|
|
501
|
-
<div class="review-stat-value" id="reviewStatValidated">0</div>
|
|
502
|
-
<div class="review-stat-label">Valides</div>
|
|
503
|
-
</div>
|
|
504
|
-
</div>
|
|
505
|
-
</aside>
|
|
506
|
-
</div>
|
|
507
|
-
</div>
|
|
508
|
-
|
|
509
|
-
<!-- Notification -->
|
|
510
|
-
<div class="notification notification-success" id="notification"></div>
|
|
511
|
-
|
|
512
|
-
<script>
|
|
513
|
-
<!-- JS_PLACEHOLDER -->
|
|
514
|
-
</script>
|
|
515
|
-
</body>
|
|
516
|
-
</html>
|
|
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="resetToEmbedded()" title="Reinitialiser depuis les donnees d'origine (supprime les modifications locales)">Reset</button>
|
|
24
|
+
<button class="btn btn-sm" onclick="saveToLocalStorage()" title="Sauvegarder les modifications dans le navigateur">Sauvegarder</button>
|
|
25
|
+
<button class="btn btn-sm btn-review" onclick="saveReviewJSON()" title="Sauvegarder les corrections pour creer une nouvelle version">Sauvegarder corrections</button>
|
|
26
|
+
<button class="btn btn-sm btn-primary" onclick="exportJSON()" title="Exporter les donnees au format JSON pour l'extraction">Exporter JSON</button>
|
|
27
|
+
<button class="btn btn-sm review-toggle-btn" id="reviewToggleBtn" onclick="toggleReviewPanel()" title="Ouvrir/fermer le panneau de review">
|
|
28
|
+
Review
|
|
29
|
+
<span class="review-badge hidden" id="reviewBadge">0</span>
|
|
30
|
+
</button>
|
|
31
|
+
</div>
|
|
32
|
+
</header>
|
|
33
|
+
|
|
34
|
+
<div class="body" id="appBody">
|
|
35
|
+
<!-- ============================================
|
|
36
|
+
SIDEBAR - Navigation hierarchique
|
|
37
|
+
============================================ -->
|
|
38
|
+
<aside class="sidebar">
|
|
39
|
+
<!-- Application Name -->
|
|
40
|
+
<div class="sidebar-header">
|
|
41
|
+
<span class="sidebar-app-name" id="sidebarAppName">{{APPLICATION_NAME}}</span>
|
|
42
|
+
</div>
|
|
43
|
+
<!-- Dynamic Tree Navigation -->
|
|
44
|
+
<div id="sidebarNav">
|
|
45
|
+
<!-- Populated by buildNavTree() -->
|
|
46
|
+
</div>
|
|
47
|
+
</aside>
|
|
48
|
+
|
|
49
|
+
<!-- ============================================
|
|
50
|
+
MAIN CONTENT
|
|
51
|
+
============================================ -->
|
|
52
|
+
<main class="main" id="mainContent">
|
|
53
|
+
|
|
54
|
+
<!-- SECTION: Contexte (merged: problem + current + vision) -->
|
|
55
|
+
<div class="section" id="cadrage-context">
|
|
56
|
+
<h2 class="section-title">Contexte du projet</h2>
|
|
57
|
+
<p class="section-subtitle">Vue synthetique du besoin : probleme, situation actuelle et objectif vise.</p>
|
|
58
|
+
|
|
59
|
+
<div style="display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;">
|
|
60
|
+
<div class="card" style="border-left:3px solid #f87171;">
|
|
61
|
+
<div class="card-label" style="color:#f87171;">Probleme identifie</div>
|
|
62
|
+
<div class="editable" contenteditable="true" data-field="context.problem" data-placeholder="Quel probleme ce projet doit-il resoudre ?"></div>
|
|
63
|
+
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
64
|
+
<strong>Declencheur :</strong>
|
|
65
|
+
<div class="editable" contenteditable="true" data-field="context.trigger" data-placeholder="Evenement declencheur" style="display:inline;"></div>
|
|
66
|
+
</div>
|
|
67
|
+
</div>
|
|
68
|
+
|
|
69
|
+
<div class="card" style="border-left:3px solid #facc15;">
|
|
70
|
+
<div class="card-label" style="color:#facc15;">Aujourd'hui</div>
|
|
71
|
+
<div class="editable" contenteditable="true" data-field="context.currentSituation" data-placeholder="Comment les choses fonctionnent actuellement ?"></div>
|
|
72
|
+
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
73
|
+
<strong>Points douleur :</strong>
|
|
74
|
+
<div class="editable" contenteditable="true" data-field="context.painPoints" data-placeholder="Problemes recurrents" style="display:inline;"></div>
|
|
75
|
+
</div>
|
|
76
|
+
</div>
|
|
77
|
+
|
|
78
|
+
<div class="card" style="border-left:3px solid #4ade80;">
|
|
79
|
+
<div class="card-label" style="color:#4ade80;">Objectif</div>
|
|
80
|
+
<div class="editable" contenteditable="true" data-field="context.desiredSituation" data-placeholder="Que doit permettre le systeme cible ?"></div>
|
|
81
|
+
<div style="margin-top:0.75rem;font-size:0.8rem;color:var(--text-muted);">
|
|
82
|
+
<strong>Criteres :</strong>
|
|
83
|
+
<div class="editable" contenteditable="true" data-field="context.acceptanceCriteria" data-placeholder="Criteres de succes" style="display:inline;"></div>
|
|
84
|
+
</div>
|
|
85
|
+
</div>
|
|
86
|
+
</div>
|
|
87
|
+
</div>
|
|
88
|
+
|
|
89
|
+
<!-- SECTION: Parties prenantes -->
|
|
90
|
+
<div class="section" id="cadrage-stakeholders" style="display:none;">
|
|
91
|
+
<h2 class="section-title">Parties prenantes</h2>
|
|
92
|
+
<p class="section-subtitle">Toutes les personnes concernees par ce projet et leurs besoins.</p>
|
|
93
|
+
|
|
94
|
+
<div class="stakeholder-grid" id="stakeholderGrid">
|
|
95
|
+
<!-- Populated dynamically -->
|
|
96
|
+
</div>
|
|
97
|
+
|
|
98
|
+
<button class="add-btn" onclick="toggleForm('addStakeholderForm')">+ Ajouter un profil utilisateur</button>
|
|
99
|
+
|
|
100
|
+
<div class="inline-form" id="addStakeholderForm">
|
|
101
|
+
<div class="inline-form-title">Nouveau profil utilisateur</div>
|
|
102
|
+
<div class="form-group">
|
|
103
|
+
<label class="form-label">Titre du profil (exemple : Responsable de production)</label>
|
|
104
|
+
<input type="text" class="form-input" id="sh-role" placeholder="Titre ou description du profil">
|
|
105
|
+
</div>
|
|
106
|
+
<div class="form-group">
|
|
107
|
+
<label class="form-label">Fonction dans l'entreprise</label>
|
|
108
|
+
<input type="text" class="form-input" id="sh-function" placeholder="Ce qu'il fait dans l'organisation">
|
|
109
|
+
</div>
|
|
110
|
+
<div class="form-group">
|
|
111
|
+
<label class="form-label">Taches principales (une par ligne)</label>
|
|
112
|
+
<textarea class="form-textarea" id="sh-tasks" placeholder="Tache 1 Tache 2 Tache 3"></textarea>
|
|
113
|
+
</div>
|
|
114
|
+
<div class="form-row">
|
|
115
|
+
<div class="form-group">
|
|
116
|
+
<label class="form-label">Frequence d'utilisation</label>
|
|
117
|
+
<select class="form-select" id="sh-frequency">
|
|
118
|
+
<option value="daily">Quotidienne</option>
|
|
119
|
+
<option value="weekly">Hebdomadaire</option>
|
|
120
|
+
<option value="monthly">Mensuelle</option>
|
|
121
|
+
<option value="occasional">Occasionnelle</option>
|
|
122
|
+
</select>
|
|
123
|
+
</div>
|
|
124
|
+
<div class="form-group">
|
|
125
|
+
<label class="form-label">Niveau d'acces</label>
|
|
126
|
+
<select class="form-select" id="sh-access">
|
|
127
|
+
<option value="admin">Administration complete</option>
|
|
128
|
+
<option value="manager">Supervision et validation</option>
|
|
129
|
+
<option value="contributor">Saisie et modification</option>
|
|
130
|
+
<option value="viewer">Consultation seule</option>
|
|
131
|
+
</select>
|
|
132
|
+
</div>
|
|
133
|
+
</div>
|
|
134
|
+
<div class="form-group">
|
|
135
|
+
<label class="form-label">Frustrations actuelles</label>
|
|
136
|
+
<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>
|
|
137
|
+
</div>
|
|
138
|
+
<div class="form-actions">
|
|
139
|
+
<button class="btn" onclick="toggleForm('addStakeholderForm')">Annuler</button>
|
|
140
|
+
<button class="btn btn-primary" onclick="addStakeholder()">Ajouter ce profil</button>
|
|
141
|
+
</div>
|
|
142
|
+
</div>
|
|
143
|
+
</div>
|
|
144
|
+
|
|
145
|
+
<!-- SECTION: Perimetre fonctionnel -->
|
|
146
|
+
<div class="section" id="cadrage-scope" style="display:none;">
|
|
147
|
+
<h2 class="section-title">Perimetre fonctionnel</h2>
|
|
148
|
+
<p class="section-subtitle">Ce que le systeme doit faire et ne pas faire, par ordre de priorite.</p>
|
|
149
|
+
|
|
150
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">
|
|
151
|
+
<span style="color: #f87171;">■</span> Fonctionnalites indispensables
|
|
152
|
+
</h3>
|
|
153
|
+
<div id="scopeVital" class="uc-list"></div>
|
|
154
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-vital')">+ Ajouter une fonctionnalite indispensable</button>
|
|
155
|
+
<div class="inline-form" id="addScopeForm-vital">
|
|
156
|
+
<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>
|
|
157
|
+
<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>
|
|
158
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-vital')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('vital')">Ajouter</button></div>
|
|
159
|
+
</div>
|
|
160
|
+
|
|
161
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
162
|
+
<span style="color: #facc15;">■</span> Fonctionnalites importantes
|
|
163
|
+
</h3>
|
|
164
|
+
<div id="scopeImportant" class="uc-list"></div>
|
|
165
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-important')">+ Ajouter une fonctionnalite importante</button>
|
|
166
|
+
<div class="inline-form" id="addScopeForm-important">
|
|
167
|
+
<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>
|
|
168
|
+
<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>
|
|
169
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-important')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('important')">Ajouter</button></div>
|
|
170
|
+
</div>
|
|
171
|
+
|
|
172
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
173
|
+
<span style="color: #4ade80;">■</span> Fonctionnalites optionnelles
|
|
174
|
+
</h3>
|
|
175
|
+
<div id="scopeOptional" class="uc-list"></div>
|
|
176
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-optional')">+ Ajouter une fonctionnalite optionnelle</button>
|
|
177
|
+
<div class="inline-form" id="addScopeForm-optional">
|
|
178
|
+
<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>
|
|
179
|
+
<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>
|
|
180
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-optional')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('optional')">Ajouter</button></div>
|
|
181
|
+
</div>
|
|
182
|
+
|
|
183
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 1.5rem 0 0.75rem;">
|
|
184
|
+
<span style="color: #94a3b8;">■</span> Hors perimetre
|
|
185
|
+
</h3>
|
|
186
|
+
<div id="scopeExcluded" class="uc-list"></div>
|
|
187
|
+
<button class="add-btn" onclick="toggleForm('addScopeForm-excluded')">+ Ajouter une exclusion</button>
|
|
188
|
+
<div class="inline-form" id="addScopeForm-excluded">
|
|
189
|
+
<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>
|
|
190
|
+
<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>
|
|
191
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addScopeForm-excluded')">Annuler</button><button class="btn btn-primary" onclick="addScopeItem('excluded')">Ajouter</button></div>
|
|
192
|
+
</div>
|
|
193
|
+
</div>
|
|
194
|
+
|
|
195
|
+
<!-- SECTION: Risques et hypotheses -->
|
|
196
|
+
<div class="section" id="cadrage-risks" style="display:none;">
|
|
197
|
+
<h2 class="section-title">Risques et hypotheses</h2>
|
|
198
|
+
<p class="section-subtitle">Ce qui pourrait mal tourner et les certitudes non verifiees.</p>
|
|
199
|
+
|
|
200
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin-bottom: 0.75rem;">Risques identifies</h3>
|
|
201
|
+
<div id="risksList"></div>
|
|
202
|
+
<button class="add-btn" onclick="toggleForm('addRiskForm')">+ Ajouter un risque</button>
|
|
203
|
+
|
|
204
|
+
<div class="inline-form" id="addRiskForm">
|
|
205
|
+
<div class="inline-form-title">Nouveau risque</div>
|
|
206
|
+
<div class="form-group">
|
|
207
|
+
<label class="form-label">Description du risque</label>
|
|
208
|
+
<input type="text" class="form-input" id="risk-desc" placeholder="Qu'est-ce qui pourrait mal tourner ?">
|
|
209
|
+
</div>
|
|
210
|
+
<div class="form-row">
|
|
211
|
+
<div class="form-group">
|
|
212
|
+
<label class="form-label">Probabilite</label>
|
|
213
|
+
<select class="form-select" id="risk-probability">
|
|
214
|
+
<option value="high">Forte</option>
|
|
215
|
+
<option value="medium">Moyenne</option>
|
|
216
|
+
<option value="low">Faible</option>
|
|
217
|
+
</select>
|
|
218
|
+
</div>
|
|
219
|
+
<div class="form-group">
|
|
220
|
+
<label class="form-label">Impact</label>
|
|
221
|
+
<select class="form-select" id="risk-impact">
|
|
222
|
+
<option value="high">Grave</option>
|
|
223
|
+
<option value="medium">Moyen</option>
|
|
224
|
+
<option value="low">Faible</option>
|
|
225
|
+
</select>
|
|
226
|
+
</div>
|
|
227
|
+
</div>
|
|
228
|
+
<div class="form-group">
|
|
229
|
+
<label class="form-label">Mesure de prevention ou de reduction</label>
|
|
230
|
+
<textarea class="form-textarea" id="risk-mitigation" placeholder="Comment prevenir ou reduire ce risque ?"></textarea>
|
|
231
|
+
</div>
|
|
232
|
+
<div class="form-actions">
|
|
233
|
+
<button class="btn" onclick="toggleForm('addRiskForm')">Annuler</button>
|
|
234
|
+
<button class="btn btn-primary" onclick="addRisk()">Ajouter ce risque</button>
|
|
235
|
+
</div>
|
|
236
|
+
</div>
|
|
237
|
+
|
|
238
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Hypotheses a verifier</h3>
|
|
239
|
+
<div class="card">
|
|
240
|
+
<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>
|
|
241
|
+
</div>
|
|
242
|
+
</div>
|
|
243
|
+
|
|
244
|
+
<!-- SECTION: Criteres de reussite -->
|
|
245
|
+
<div class="section" id="cadrage-success" style="display:none;">
|
|
246
|
+
<h2 class="section-title">Criteres de reussite</h2>
|
|
247
|
+
<p class="section-subtitle">Comment mesurer objectivement que le projet est un succes.</p>
|
|
248
|
+
|
|
249
|
+
<div class="card">
|
|
250
|
+
<div class="card-label">Definition du succes</div>
|
|
251
|
+
<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>
|
|
252
|
+
</div>
|
|
253
|
+
|
|
254
|
+
<div class="card" data-vibe-hide>
|
|
255
|
+
<div class="card-label">Objectifs mesurables</div>
|
|
256
|
+
<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>
|
|
257
|
+
</div>
|
|
258
|
+
|
|
259
|
+
<div class="card" data-vibe-hide>
|
|
260
|
+
<div class="card-label">Delai d'evaluation</div>
|
|
261
|
+
<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>
|
|
262
|
+
</div>
|
|
263
|
+
|
|
264
|
+
<div class="card" data-vibe-hide>
|
|
265
|
+
<div class="card-label">Conditions minimales de mise en service</div>
|
|
266
|
+
<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>
|
|
267
|
+
</div>
|
|
268
|
+
|
|
269
|
+
<h3 style="color: var(--text-bright); font-size: 1rem; margin: 2rem 0 0.75rem;">Criteres d'acceptation</h3>
|
|
270
|
+
<p style="font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem;">Criteres concrets et mesurables pour valider le succes du projet.</p>
|
|
271
|
+
<div id="criteriaList" class="uc-list"></div>
|
|
272
|
+
<button class="add-btn" onclick="toggleForm('addCriterionForm')">+ Ajouter un critere d'acceptation</button>
|
|
273
|
+
<div class="inline-form" id="addCriterionForm">
|
|
274
|
+
<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>
|
|
275
|
+
<div class="form-actions"><button class="btn" onclick="toggleForm('addCriterionForm')">Annuler</button><button class="btn btn-primary" onclick="addCriterion()">Ajouter</button></div>
|
|
276
|
+
</div>
|
|
277
|
+
</div>
|
|
278
|
+
|
|
279
|
+
<!-- ================================================================
|
|
280
|
+
PHASE 2 : DECOMPOSITION
|
|
281
|
+
================================================================ -->
|
|
282
|
+
|
|
283
|
+
<!-- SECTION: Domaines fonctionnels -->
|
|
284
|
+
<div class="section" id="decomp-modules" style="display:none;">
|
|
285
|
+
<h2 class="section-title">Domaines fonctionnels</h2>
|
|
286
|
+
<p class="section-subtitle">Identifiez les grands domaines de votre application. Chaque domaine regroupe des fonctionnalites coherentes et independantes.</p>
|
|
287
|
+
|
|
288
|
+
<div class="module-grid" id="moduleGrid">
|
|
289
|
+
<!-- Populated dynamically -->
|
|
290
|
+
</div>
|
|
291
|
+
|
|
292
|
+
<button class="add-btn" onclick="toggleForm('addModuleForm')" style="margin-top:1rem;">+ Ajouter un domaine fonctionnel</button>
|
|
293
|
+
|
|
294
|
+
<div class="inline-form" id="addModuleForm">
|
|
295
|
+
<div class="inline-form-title">Nouveau domaine fonctionnel</div>
|
|
296
|
+
<div class="form-group">
|
|
297
|
+
<label class="form-label">Nom du domaine (exemple : Gestion des commandes)</label>
|
|
298
|
+
<input type="text" class="form-input" id="mod-name" placeholder="Nom clair et explicite">
|
|
299
|
+
</div>
|
|
300
|
+
<div class="form-group">
|
|
301
|
+
<label class="form-label">Description en une ou deux phrases</label>
|
|
302
|
+
<textarea class="form-textarea" id="mod-desc" placeholder="A quoi sert ce domaine ? Quel probleme resout-il ?"></textarea>
|
|
303
|
+
</div>
|
|
304
|
+
<div class="form-row">
|
|
305
|
+
<div class="form-group">
|
|
306
|
+
<label class="form-label">Type de domaine</label>
|
|
307
|
+
<select class="form-select" id="mod-type">
|
|
308
|
+
<option value="data-centric">Gestion de donnees (listes, fiches, formulaires)</option>
|
|
309
|
+
<option value="workflow">Processus metier (etapes, validations, approbations)</option>
|
|
310
|
+
<option value="reporting">Tableaux de bord et rapports</option>
|
|
311
|
+
<option value="integration">Integration avec des systemes externes</option>
|
|
312
|
+
<option value="full-module">Domaine complet (donnees + processus + rapports)</option>
|
|
313
|
+
</select>
|
|
314
|
+
</div>
|
|
315
|
+
<div class="form-group">
|
|
316
|
+
<label class="form-label">Priorite</label>
|
|
317
|
+
<select class="form-select" id="mod-priority">
|
|
318
|
+
<option value="must">Indispensable</option>
|
|
319
|
+
<option value="should">Important</option>
|
|
320
|
+
<option value="could">Optionnel</option>
|
|
321
|
+
</select>
|
|
322
|
+
</div>
|
|
323
|
+
</div>
|
|
324
|
+
<div class="form-group">
|
|
325
|
+
<label class="form-label">Principales donnees gerees (une par ligne)</label>
|
|
326
|
+
<textarea class="form-textarea" id="mod-entities" placeholder="Commande Ligne de commande Facture"></textarea>
|
|
327
|
+
</div>
|
|
328
|
+
<div class="form-actions">
|
|
329
|
+
<button class="btn" onclick="toggleForm('addModuleForm')">Annuler</button>
|
|
330
|
+
<button class="btn btn-primary" onclick="addModule()">Ajouter ce domaine</button>
|
|
331
|
+
</div>
|
|
332
|
+
</div>
|
|
333
|
+
</div>
|
|
334
|
+
|
|
335
|
+
<!-- SECTION: Dependances -->
|
|
336
|
+
<div class="section" id="decomp-dependencies" style="display:none;">
|
|
337
|
+
<h2 class="section-title">Dependances entre domaines</h2>
|
|
338
|
+
<p class="section-subtitle">Indiquez quels domaines dependent d'autres domaines. Par exemple, les Commandes dependent des Clients et des Produits.</p>
|
|
339
|
+
|
|
340
|
+
<div id="depGraphContainer">
|
|
341
|
+
<div class="dep-graph" id="depGraph">
|
|
342
|
+
<p style="color:var(--text-muted);text-align:center;padding:2rem;">Ajoutez des domaines fonctionnels pour visualiser les dependances.</p>
|
|
343
|
+
</div>
|
|
344
|
+
</div>
|
|
345
|
+
|
|
346
|
+
<div style="margin-top:1.5rem;">
|
|
347
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ajouter une dependance</h3>
|
|
348
|
+
<div class="form-row">
|
|
349
|
+
<div class="form-group">
|
|
350
|
+
<label class="form-label">Ce domaine...</label>
|
|
351
|
+
<select class="form-select" id="dep-from"></select>
|
|
352
|
+
</div>
|
|
353
|
+
<div class="form-group">
|
|
354
|
+
<label class="form-label">...depend de</label>
|
|
355
|
+
<select class="form-select" id="dep-to"></select>
|
|
356
|
+
</div>
|
|
357
|
+
</div>
|
|
358
|
+
<div class="form-group">
|
|
359
|
+
<label class="form-label">Nature de la dependance</label>
|
|
360
|
+
<input type="text" class="form-input" id="dep-desc" placeholder="Exemple : La commande reference un client existant">
|
|
361
|
+
</div>
|
|
362
|
+
<button class="btn btn-primary" onclick="addDependency()" style="margin-top:0.5rem;">Ajouter cette dependance</button>
|
|
363
|
+
</div>
|
|
364
|
+
|
|
365
|
+
<div id="depList" style="margin-top:1.5rem;"></div>
|
|
366
|
+
|
|
367
|
+
<div style="margin-top:2rem;">
|
|
368
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Ordre de traitement propose</h3>
|
|
369
|
+
<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>
|
|
370
|
+
<div id="processingOrder" class="process-flow"></div>
|
|
371
|
+
</div>
|
|
372
|
+
</div>
|
|
373
|
+
|
|
374
|
+
<!-- ================================================================
|
|
375
|
+
PHASE 3 : SPECIFICATION PAR MODULE
|
|
376
|
+
================================================================ -->
|
|
377
|
+
|
|
378
|
+
<!-- Container dynamique pour les specs de chaque module -->
|
|
379
|
+
<div id="moduleSpecContainer">
|
|
380
|
+
<!-- Generated dynamically by renderModuleSpec() -->
|
|
381
|
+
</div>
|
|
382
|
+
|
|
383
|
+
<!-- ================================================================
|
|
384
|
+
PHASE 4 : CONSOLIDATION
|
|
385
|
+
================================================================ -->
|
|
386
|
+
|
|
387
|
+
<!-- SECTION: Modele de donnees -->
|
|
388
|
+
<div class="section" id="consol-datamodel" style="display:none;">
|
|
389
|
+
<h2 class="section-title">Modele de donnees</h2>
|
|
390
|
+
<p class="section-subtitle">Vue d'ensemble de toutes les entites metier, leurs attributs et leurs relations entre domaines.</p>
|
|
391
|
+
<div id="dataModelContainer">
|
|
392
|
+
<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>
|
|
393
|
+
</div>
|
|
394
|
+
</div>
|
|
395
|
+
|
|
396
|
+
<!-- SECTION: Interactions cross-module -->
|
|
397
|
+
<div class="section" id="consol-interactions" style="display:none;">
|
|
398
|
+
<h2 class="section-title">Interactions entre domaines</h2>
|
|
399
|
+
<p class="section-subtitle">Vue d'ensemble de la facon dont les domaines communiquent et partagent des donnees.</p>
|
|
400
|
+
<div id="consolInteractions">
|
|
401
|
+
<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>
|
|
402
|
+
</div>
|
|
403
|
+
</div>
|
|
404
|
+
|
|
405
|
+
<!-- SECTION: Coherence des acces -->
|
|
406
|
+
<div class="section" id="consol-permissions" style="display:none;">
|
|
407
|
+
<h2 class="section-title">Coherence des droits d'acces</h2>
|
|
408
|
+
<p class="section-subtitle">Verification que les profils utilisateurs ont des droits coherents dans tous les domaines.</p>
|
|
409
|
+
<div id="consolPermissions">
|
|
410
|
+
<p style="color:var(--text-muted);text-align:center;padding:2rem;">La coherence sera verifiee quand les permissions de chaque domaine seront definies.</p>
|
|
411
|
+
</div>
|
|
412
|
+
</div>
|
|
413
|
+
|
|
414
|
+
<!-- SECTION: Parcours bout en bout -->
|
|
415
|
+
<div class="section" id="consol-flows" style="display:none;">
|
|
416
|
+
<h2 class="section-title">Parcours bout en bout</h2>
|
|
417
|
+
<p class="section-subtitle">Les processus metier qui traversent plusieurs domaines, de bout en bout.</p>
|
|
418
|
+
|
|
419
|
+
<div id="e2eFlowsList"></div>
|
|
420
|
+
|
|
421
|
+
<button class="add-btn" onclick="toggleForm('addFlowForm')">+ Ajouter un parcours</button>
|
|
422
|
+
|
|
423
|
+
<div class="inline-form" id="addFlowForm">
|
|
424
|
+
<div class="inline-form-title">Nouveau parcours bout en bout</div>
|
|
425
|
+
<div class="form-group">
|
|
426
|
+
<label class="form-label">Nom du parcours (exemple : De la commande a la facture)</label>
|
|
427
|
+
<input type="text" class="form-input" id="flow-name" placeholder="Nom descriptif du parcours">
|
|
428
|
+
</div>
|
|
429
|
+
<div class="form-group">
|
|
430
|
+
<label class="form-label">Etapes du parcours (une par ligne : Domaine - Action)</label>
|
|
431
|
+
<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>
|
|
432
|
+
</div>
|
|
433
|
+
<div class="form-group">
|
|
434
|
+
<label class="form-label">Qui intervient dans ce parcours ?</label>
|
|
435
|
+
<input type="text" class="form-input" id="flow-actors" placeholder="Exemple : Contributeur (creation), Responsable (validation)">
|
|
436
|
+
</div>
|
|
437
|
+
<div class="form-actions">
|
|
438
|
+
<button class="btn" onclick="toggleForm('addFlowForm')">Annuler</button>
|
|
439
|
+
<button class="btn btn-primary" onclick="addE2EFlow()">Ajouter ce parcours</button>
|
|
440
|
+
</div>
|
|
441
|
+
</div>
|
|
442
|
+
</div>
|
|
443
|
+
|
|
444
|
+
<!-- ================================================================
|
|
445
|
+
PHASE 5 : SYNTHESE
|
|
446
|
+
================================================================ -->
|
|
447
|
+
|
|
448
|
+
<div class="section" id="handoff-summary" style="display:none;">
|
|
449
|
+
<h2 class="section-title">Synthese de l'analyse</h2>
|
|
450
|
+
<p class="section-subtitle">Vue d'ensemble de toute l'analyse metier, prete pour le developpement.</p>
|
|
451
|
+
|
|
452
|
+
<div class="stat-grid" id="handoffStats">
|
|
453
|
+
<!-- Populated dynamically -->
|
|
454
|
+
</div>
|
|
455
|
+
|
|
456
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin-bottom:0.75rem;">Domaines par ordre de traitement</h3>
|
|
457
|
+
<div id="handoffModuleList"></div>
|
|
458
|
+
|
|
459
|
+
<h3 style="color:var(--text-bright);font-size:1rem;margin:1.5rem 0 0.75rem;">Couverture du besoin initial</h3>
|
|
460
|
+
<div class="card">
|
|
461
|
+
<div class="card-label">Matrice de couverture</div>
|
|
462
|
+
<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>
|
|
463
|
+
<div id="coverageMatrix"></div>
|
|
464
|
+
</div>
|
|
465
|
+
|
|
466
|
+
<div style="margin-top:2rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;text-align:center;">
|
|
467
|
+
<p style="color:var(--text-bright);font-size:1.1rem;font-weight:600;margin-bottom:0.5rem;">Analyse prete pour l'extraction</p>
|
|
468
|
+
<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>
|
|
469
|
+
<button class="btn btn-primary" onclick="exportJSON()" style="font-size:0.9rem;padding:0.6rem 1.5rem;">Exporter l'analyse complete en JSON</button>
|
|
470
|
+
</div>
|
|
471
|
+
</div>
|
|
472
|
+
|
|
473
|
+
</main>
|
|
474
|
+
|
|
475
|
+
<!-- ============================================
|
|
476
|
+
REVIEW PANEL (right sidebar)
|
|
477
|
+
============================================ -->
|
|
478
|
+
<aside class="review-panel" id="reviewPanel">
|
|
479
|
+
<div class="review-panel-header">
|
|
480
|
+
<span class="review-panel-title">Review</span>
|
|
481
|
+
<button class="review-panel-close" onclick="toggleReviewPanel()" title="Fermer">×</button>
|
|
482
|
+
</div>
|
|
483
|
+
<div class="review-filters">
|
|
484
|
+
<button class="review-filter-btn active" onclick="filterReviewComments('all')" data-filter="all">Tous</button>
|
|
485
|
+
<button class="review-filter-btn" onclick="filterReviewComments('to-review')" data-filter="to-review">A revoir</button>
|
|
486
|
+
<button class="review-filter-btn" onclick="filterReviewComments('validated')" data-filter="validated">Valides</button>
|
|
487
|
+
</div>
|
|
488
|
+
<div class="review-comments" id="reviewCommentsList">
|
|
489
|
+
<div class="review-empty">Aucun commentaire pour le moment.</div>
|
|
490
|
+
</div>
|
|
491
|
+
<div class="review-stats" id="reviewStats">
|
|
492
|
+
<div class="review-stat">
|
|
493
|
+
<div class="review-stat-value" id="reviewStatTotal">0</div>
|
|
494
|
+
<div class="review-stat-label">Total</div>
|
|
495
|
+
</div>
|
|
496
|
+
<div class="review-stat">
|
|
497
|
+
<div class="review-stat-value" id="reviewStatToReview">0</div>
|
|
498
|
+
<div class="review-stat-label">A revoir</div>
|
|
499
|
+
</div>
|
|
500
|
+
<div class="review-stat">
|
|
501
|
+
<div class="review-stat-value" id="reviewStatValidated">0</div>
|
|
502
|
+
<div class="review-stat-label">Valides</div>
|
|
503
|
+
</div>
|
|
504
|
+
</div>
|
|
505
|
+
</aside>
|
|
506
|
+
</div>
|
|
507
|
+
</div>
|
|
508
|
+
|
|
509
|
+
<!-- Notification -->
|
|
510
|
+
<div class="notification notification-success" id="notification"></div>
|
|
511
|
+
|
|
512
|
+
<script>
|
|
513
|
+
<!-- JS_PLACEHOLDER -->
|
|
514
|
+
</script>
|
|
515
|
+
</body>
|
|
516
|
+
</html>
|