tribunal-kit 4.4.0 → 4.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. package/.agent/agents/api-architect.md +66 -66
  2. package/.agent/agents/db-latency-auditor.md +216 -216
  3. package/.agent/agents/precedence-reviewer.md +250 -250
  4. package/.agent/agents/resilience-reviewer.md +88 -88
  5. package/.agent/agents/schema-reviewer.md +67 -67
  6. package/.agent/agents/throughput-optimizer.md +299 -299
  7. package/.agent/agents/ui-ux-auditor.md +292 -292
  8. package/.agent/agents/vitals-reviewer.md +223 -223
  9. package/.agent/history/architecture-graph.yaml +32 -1
  10. package/.agent/history/graph-cache.json +66 -19
  11. package/.agent/history/snapshots/bin__tribunal-kit.js.json +19 -0
  12. package/.agent/history/snapshots/eslint.config.js.json +9 -0
  13. package/.agent/history/snapshots/migrate_refs.js.json +3 -3
  14. package/.agent/history/snapshots/scripts__changelog.js.json +2 -1
  15. package/.agent/history/snapshots/scripts__sync-version.js.json +2 -1
  16. package/.agent/history/snapshots/scripts__validate-payload.js.json +1 -0
  17. package/.agent/history/snapshots/test__integration__bridges.test.js.json +2 -1
  18. package/.agent/history/snapshots/test__integration__init.test.js.json +1 -0
  19. package/.agent/history/snapshots/test__integration__routing.test.js.json +1 -0
  20. package/.agent/history/snapshots/test__integration__swarm_dispatcher.test.js.json +2 -1
  21. package/.agent/history/snapshots/test__integration__wave2.test.js.json +2 -1
  22. package/.agent/history/snapshots/test__unit__args.test.js.json +11 -1
  23. package/.agent/history/snapshots/test__unit__case_law_manager.test.js.json +1 -0
  24. package/.agent/history/snapshots/test__unit__context_broker.test.js.json +11 -0
  25. package/.agent/history/snapshots/test__unit__copyDir.test.js.json +11 -1
  26. package/.agent/history/snapshots/test__unit__graph_tools.test.js.json +1 -0
  27. package/.agent/history/snapshots/test__unit__inner_loop_validator.test.js.json +11 -0
  28. package/.agent/history/snapshots/test__unit__selfInstall.test.js.json +11 -1
  29. package/.agent/history/snapshots/test__unit__semver.test.js.json +11 -1
  30. package/.agent/history/snapshots/test__unit__swarm_dispatcher.test.js.json +1 -0
  31. package/.agent/scripts/_colors.js +154 -2
  32. package/.agent/scripts/_utils.js +205 -3
  33. package/.agent/scripts/append_flow.js +72 -72
  34. package/.agent/scripts/auto_preview.js +197 -197
  35. package/.agent/scripts/bundle_analyzer.js +90 -119
  36. package/.agent/scripts/case_law_manager.js +18 -13
  37. package/.agent/scripts/checklist.js +100 -88
  38. package/.agent/scripts/colors.js +7 -13
  39. package/.agent/scripts/compress_skills.js +141 -141
  40. package/.agent/scripts/consolidate_skills.js +149 -149
  41. package/.agent/scripts/context_broker.js +605 -609
  42. package/.agent/scripts/deep_compress.js +150 -150
  43. package/.agent/scripts/dependency_analyzer.js +68 -106
  44. package/.agent/scripts/graph_builder.js +341 -311
  45. package/.agent/scripts/graph_visualizer.js +390 -384
  46. package/.agent/scripts/graph_zoom.js +6 -4
  47. package/.agent/scripts/inner_loop_validator.js +445 -465
  48. package/.agent/scripts/lint_runner.js +27 -28
  49. package/.agent/scripts/minify_context.js +100 -100
  50. package/.agent/scripts/mutation_runner.js +280 -280
  51. package/.agent/scripts/patch_skills_meta.js +156 -156
  52. package/.agent/scripts/patch_skills_output.js +244 -244
  53. package/.agent/scripts/schema_validator.js +280 -297
  54. package/.agent/scripts/security_scan.js +37 -64
  55. package/.agent/scripts/session_manager.js +270 -276
  56. package/.agent/scripts/skill_evolution.js +637 -644
  57. package/.agent/scripts/skill_integrator.js +307 -313
  58. package/.agent/scripts/strengthen_skills.js +193 -193
  59. package/.agent/scripts/strip_tribunal.js +47 -47
  60. package/.agent/scripts/swarm_dispatcher.js +360 -360
  61. package/.agent/scripts/test_runner.js +32 -39
  62. package/.agent/scripts/utils.js +10 -25
  63. package/.agent/scripts/verify_all.js +84 -92
  64. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +1 -1
  65. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +1 -1
  66. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +1 -1
  67. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +1 -1
  68. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +1 -1
  69. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +1 -1
  70. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +1 -1
  71. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +1 -1
  72. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +1 -1
  73. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +1 -1
  74. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +1 -1
  75. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +1 -1
  76. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +1 -1
  77. package/.agent/skills/doc.md +1 -1
  78. package/.agent/skills/knowledge-graph/SKILL.md +52 -52
  79. package/.agent/skills/ui-ux-pro-max/SKILL.md +562 -562
  80. package/.agent/workflows/generate.md +183 -183
  81. package/.agent/workflows/tribunal-speed.md +183 -183
  82. package/README.md +1 -1
  83. package/bin/tribunal-kit.js +76 -87
  84. package/package.json +6 -3
  85. package/scripts/changelog.js +167 -167
  86. package/scripts/sync-version.js +81 -81
  87. package/.agent/history/architecture-explorer.html +0 -352
  88. package/.agent/scripts/__pycache__/_colors.cpython-311.pyc +0 -0
  89. package/.agent/scripts/__pycache__/_utils.cpython-311.pyc +0 -0
  90. package/.agent/scripts/__pycache__/case_law_manager.cpython-311.pyc +0 -0
@@ -1,352 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="UTF-8">
5
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
- <title>Tribunal Architecture Explorer</title>
7
- <style>
8
- :root {
9
- --bg: #09090b;
10
- --panel-bg: rgba(24, 24, 27, 0.8);
11
- --border: #27272a;
12
- --text: #e4e4e7;
13
- --text-dim: #a1a1aa;
14
- --critical: #ef4444;
15
- --high: #f97316;
16
- --medium: #eab308;
17
- --low: #3b82f6;
18
- --edge: rgba(255, 255, 255, 0.1);
19
- }
20
- body {
21
- margin: 0;
22
- padding: 0;
23
- background: var(--bg);
24
- color: var(--text);
25
- font-family: system-ui, -apple-system, sans-serif;
26
- overflow: hidden;
27
- }
28
- canvas {
29
- display: block;
30
- width: 100vw;
31
- height: 100vh;
32
- }
33
- #ui-panel {
34
- position: absolute;
35
- top: 20px;
36
- left: 20px;
37
- width: 320px;
38
- background: var(--panel-bg);
39
- backdrop-filter: blur(12px);
40
- border: 1px solid var(--border);
41
- border-radius: 12px;
42
- padding: 20px;
43
- box-shadow: 0 10px 30px rgba(0,0,0,0.5);
44
- pointer-events: none; /* Let clicks pass to canvas if not on panel */
45
- }
46
- h1 { margin: 0 0 10px 0; font-size: 1.2rem; font-weight: 600; }
47
- .stat { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 0.9rem; }
48
- .stat .val { font-family: monospace; color: white; }
49
- .legend { margin-top: 20px; display: grid; gap: 8px; font-size: 0.85rem; }
50
- .legend-item { display: flex; align-items: center; gap: 8px; }
51
- .dot { width: 10px; height: 10px; border-radius: 50%; }
52
-
53
- #node-details {
54
- margin-top: 20px;
55
- padding-top: 20px;
56
- border-top: 1px solid var(--border);
57
- display: none;
58
- pointer-events: auto;
59
- }
60
- #node-details h2 { margin: 0 0 10px 0; font-size: 1rem; word-break: break-all; }
61
- .detail-row { font-size: 0.85rem; margin-bottom: 4px; color: var(--text-dim); }
62
- .badge { display: inline-block; padding: 2px 6px; border-radius: 4px; font-size: 0.75rem; font-weight: bold; color: black; }
63
- ul { margin: 8px 0; padding-left: 20px; font-size: 0.85rem; color: var(--text-dim); max-height: 150px; overflow-y: auto; }
64
- </style>
65
- </head>
66
- <body>
67
-
68
- <canvas id="graph"></canvas>
69
-
70
- <div id="ui-panel">
71
- <h1>Tribunal Architecture</h1>
72
- <div class="stat"><span>Nodes</span><span class="val" id="stat-nodes">0</span></div>
73
- <div class="stat"><span>Edges</span><span class="val" id="stat-edges">0</span></div>
74
-
75
- <div class="legend">
76
- <div class="legend-item"><div class="dot" style="background: var(--critical)"></div> Critical (>10 dependents)</div>
77
- <div class="legend-item"><div class="dot" style="background: var(--high)"></div> High (5-10 dependents)</div>
78
- <div class="legend-item"><div class="dot" style="background: var(--medium)"></div> Medium (2-4 dependents)</div>
79
- <div class="legend-item"><div class="dot" style="background: var(--low)"></div> Low (0-1 dependents)</div>
80
- </div>
81
-
82
- <div id="node-details">
83
- <h2 id="nd-title">file.js</h2>
84
- <div class="detail-row">Risk Score: <span id="nd-risk" class="badge">Low</span></div>
85
- <div class="detail-row">Blast Radius: <span id="nd-blast" style="color:white;font-weight:bold">0</span> files</div>
86
- <div class="detail-row" style="margin-top:10px">Imports:</div>
87
- <ul id="nd-imports"></ul>
88
- <div class="detail-row">Dependents:</div>
89
- <ul id="nd-dependents"></ul>
90
- </div>
91
- </div>
92
-
93
- <script>
94
- const rawData = JSON.parse(decodeURIComponent("%7B%0A%20%20%22bin%2Ftribunal-kit.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201777189133916.1414%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22https%22%2C%0A%20%20%20%20%20%20%22child_process%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%0A%20%20%20%20%20%20%22parseArgs%22%2C%0A%20%20%20%20%20%20%22compareSemver%22%2C%0A%20%20%20%20%20%20%22copyDir%22%2C%0A%20%20%20%20%20%20%22countDir%22%2C%0A%20%20%20%20%20%20%22isSelfInstall%22%2C%0A%20%20%20%20%20%20%22CORE_AGENTS%22%2C%0A%20%20%20%20%20%20%22CORE_SKILLS%22%2C%0A%20%20%20%20%20%20%22generateIDEBridges%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%0A%20%20%20%20%20%20%22test%2Funit%2Fargs.test.js%22%2C%0A%20%20%20%20%20%20%22test%2Funit%2FcopyDir.test.js%22%2C%0A%20%20%20%20%20%20%22test%2Funit%2FselfInstall.test.js%22%2C%0A%20%20%20%20%20%20%22test%2Funit%2Fsemver.test.js%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Medium%22%2C%0A%20%20%20%20%22blastRadius%22%3A%204%0A%20%20%7D%2C%0A%20%20%22migrate_refs.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776601517571.4077%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22scripts%2Fchangelog.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776707395005.7876%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22child_process%22%2C%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22scripts%2Fsync-version.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776539656195.906%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22scripts%2Fvalidate-payload.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201777143609713.3955%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Fintegration%2Fbridges.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543968182.8357%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22child_process%22%2C%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22os%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Fintegration%2Finit.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898784.1787%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22child_process%22%2C%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22os%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Fintegration%2Frouting.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898785.1748%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Fintegration%2Fswarm_dispatcher.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776601326063.697%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22os%22%2C%0A%20%20%20%20%20%20%22..%2F..%2F.agent%2Fscripts%2Fswarm_dispatcher.js%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Fintegration%2Fwave2.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776602944314.9893%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22..%2F..%2F.agent%2Fscripts%2Fskill_integrator.js%22%2C%0A%20%20%20%20%20%20%22..%2F..%2F.agent%2Fscripts%2Fskill_evolution.js%22%2C%0A%20%20%20%20%20%20%22..%2F..%2F.agent%2Fscripts%2Fcase_law_manager.js%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2Fargs.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898786.9612%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22..%2F..%2Fbin%2Ftribunal-kit%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2Fcase_law_manager.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201777143609717.9287%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22..%2F..%2F.agent%2Fscripts%2Fcase_law_manager%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2FcopyDir.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898787.971%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22os%22%2C%0A%20%20%20%20%20%20%22..%2F..%2Fbin%2Ftribunal-kit%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2Fgraph_tools.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201777143609718.4546%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22path%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2FselfInstall.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898788.9712%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%2C%0A%20%20%20%20%20%20%22os%22%2C%0A%20%20%20%20%20%20%22..%2F..%2Fbin%2Ftribunal-kit%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2Fsemver.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201776543898789.971%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22..%2F..%2Fbin%2Ftribunal-kit%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%2C%0A%20%20%22test%2Funit%2Fswarm_dispatcher.test.js%22%3A%20%7B%0A%20%20%20%20%22mtimeMs%22%3A%201777143609719.6228%2C%0A%20%20%20%20%22imports%22%3A%20%5B%0A%20%20%20%20%20%20%22path%22%2C%0A%20%20%20%20%20%20%22fs%22%0A%20%20%20%20%5D%2C%0A%20%20%20%20%22exports%22%3A%20%5B%5D%2C%0A%20%20%20%20%22dependents%22%3A%20%5B%5D%2C%0A%20%20%20%20%22riskScore%22%3A%20%22Low%22%2C%0A%20%20%20%20%22blastRadius%22%3A%200%0A%20%20%7D%0A%7D"));
95
-
96
- const nodes = [];
97
- const edges = [];
98
- const nodeMap = new Map();
99
-
100
- // Build Nodes
101
- Object.keys(rawData).forEach(file => {
102
- const info = rawData[file];
103
- const node = {
104
- id: file,
105
- imports: info.imports || [],
106
- dependents: info.dependents || [],
107
- riskScore: info.riskScore || 'Low',
108
- blastRadius: info.blastRadius || 0,
109
- x: Math.random() * window.innerWidth,
110
- y: Math.random() * window.innerHeight,
111
- vx: 0,
112
- vy: 0,
113
- radius: Math.min(20, Math.max(5, 5 + (info.blastRadius * 1.5)))
114
- };
115
-
116
- if (node.riskScore === 'Critical') node.color = '#ef4444';
117
- else if (node.riskScore === 'High') node.color = '#f97316';
118
- else if (node.riskScore === 'Medium') node.color = '#eab308';
119
- else node.color = '#3b82f6';
120
-
121
- nodes.push(node);
122
- nodeMap.set(file, node);
123
- });
124
-
125
- // Build Edges
126
- nodes.forEach(node => {
127
- node.imports.forEach(imp => {
128
- if (imp.startsWith('.')) {
129
- // Try to resolve
130
- const dir = node.id.split('/').slice(0, -1).join('/');
131
- let resolved = dir ? dir + '/' + imp.replace('./', '') : imp.replace('./', '');
132
-
133
- // Normalize standard paths relative to array
134
- let target = nodes.find(n => n.id === resolved || n.id === resolved + '.js' || n.id === resolved + '.ts');
135
- if (target) {
136
- edges.push({ source: node, target: target });
137
- }
138
- }
139
- });
140
- });
141
-
142
- document.getElementById('stat-nodes').innerText = nodes.length;
143
- document.getElementById('stat-edges').innerText = edges.length;
144
-
145
- // Force Directed Graph Simulation
146
- const canvas = document.getElementById('graph');
147
- const ctx = canvas.getContext('2d');
148
-
149
- function resize() {
150
- canvas.width = window.innerWidth;
151
- canvas.height = window.innerHeight;
152
- }
153
- window.addEventListener('resize', resize);
154
- resize();
155
-
156
- let hoveredNode = null;
157
- let selectedNode = null;
158
- let isDragging = false;
159
-
160
- // Physics constants
161
- const REPULSION = 2000;
162
- const SPRING_LENGTH = 100;
163
- const SPRING_STRENGTH = 0.05;
164
- const DAMPING = 0.85;
165
-
166
- function simulate() {
167
- // Repulsion
168
- for (let i = 0; i < nodes.length; i++) {
169
- for (let j = i + 1; j < nodes.length; j++) {
170
- const n1 = nodes[i];
171
- const n2 = nodes[j];
172
- const dx = n2.x - n1.x;
173
- const dy = n2.y - n1.y;
174
- let dist = Math.sqrt(dx*dx + dy*dy) || 1;
175
- if (dist < 300) {
176
- const force = REPULSION / (dist * dist);
177
- const fx = (dx / dist) * force;
178
- const fy = (dy / dist) * force;
179
- n1.vx -= fx;
180
- n1.vy -= fy;
181
- n2.vx += fx;
182
- n2.vy += fy;
183
- }
184
- }
185
- }
186
-
187
- // Attraction (Springs)
188
- edges.forEach(edge => {
189
- const dx = edge.target.x - edge.source.x;
190
- const dy = edge.target.y - edge.source.y;
191
- const dist = Math.sqrt(dx*dx + dy*dy) || 1;
192
- const force = (dist - SPRING_LENGTH) * SPRING_STRENGTH;
193
- const fx = (dx / dist) * force;
194
- const fy = (dy / dist) * force;
195
-
196
- edge.source.vx += fx;
197
- edge.source.vy += fy;
198
- edge.target.vx -= fx;
199
- edge.target.vy -= fy;
200
- });
201
-
202
- // Center gravity
203
- const cx = canvas.width / 2;
204
- const cy = canvas.height / 2;
205
- nodes.forEach(n => {
206
- n.vx += (cx - n.x) * 0.01;
207
- n.vy += (cy - n.y) * 0.01;
208
- });
209
-
210
- // Update positions
211
- nodes.forEach(n => {
212
- if (n === selectedNode && isDragging) return; // don't move dragged node
213
- n.vx *= DAMPING;
214
- n.vy *= DAMPING;
215
- n.x += n.vx;
216
- n.y += n.vy;
217
- });
218
- }
219
-
220
- function draw() {
221
- ctx.clearRect(0, 0, canvas.width, canvas.height);
222
-
223
- // Draw edges
224
- ctx.lineWidth = 1;
225
- edges.forEach(edge => {
226
- let isHighlighted = false;
227
- if (hoveredNode) {
228
- isHighlighted = (edge.source === hoveredNode || edge.target === hoveredNode);
229
- } else if (selectedNode) {
230
- isHighlighted = (edge.source === selectedNode || edge.target === selectedNode);
231
- }
232
-
233
- if (hoveredNode || selectedNode) {
234
- ctx.strokeStyle = isHighlighted ? 'rgba(255,255,255,0.8)' : 'rgba(255,255,255,0.05)';
235
- ctx.lineWidth = isHighlighted ? 2 : 1;
236
- } else {
237
- ctx.strokeStyle = 'rgba(255,255,255,0.15)';
238
- ctx.lineWidth = 1;
239
- }
240
-
241
- ctx.beginPath();
242
- ctx.moveTo(edge.source.x, edge.source.y);
243
- ctx.lineTo(edge.target.x, edge.target.y);
244
- ctx.stroke();
245
- });
246
-
247
- // Draw nodes
248
- nodes.forEach(n => {
249
- let opacity = 1;
250
- if (hoveredNode && n !== hoveredNode && !edges.some(e => (e.source===hoveredNode && e.target===n) || (e.target===hoveredNode && e.source===n))) {
251
- opacity = 0.2;
252
- } else if (selectedNode && !hoveredNode && n !== selectedNode && !edges.some(e => (e.source===selectedNode && e.target===n) || (e.target===selectedNode && e.source===n))) {
253
- opacity = 0.2;
254
- }
255
-
256
- ctx.beginPath();
257
- ctx.arc(n.x, n.y, n.radius, 0, Math.PI * 2);
258
- ctx.fillStyle = n.color;
259
- ctx.globalAlpha = opacity;
260
- ctx.fill();
261
-
262
- if (n === hoveredNode || n === selectedNode) {
263
- ctx.strokeStyle = '#fff';
264
- ctx.lineWidth = 2;
265
- ctx.stroke();
266
-
267
- ctx.globalAlpha = 1;
268
- ctx.fillStyle = '#fff';
269
- ctx.font = '12px system-ui';
270
- ctx.fillText(n.id.split('/').pop(), n.x + n.radius + 5, n.y + 4);
271
- }
272
- ctx.globalAlpha = 1;
273
- });
274
- }
275
-
276
- function loop() {
277
- simulate();
278
- draw();
279
- requestAnimationFrame(loop);
280
- }
281
- loop();
282
-
283
- // Interaction
284
- canvas.addEventListener('mousemove', e => {
285
- const rect = canvas.getBoundingClientRect();
286
- const mx = e.clientX - rect.left;
287
- const my = e.clientY - rect.top;
288
-
289
- if (isDragging && selectedNode) {
290
- selectedNode.x = mx;
291
- selectedNode.y = my;
292
- return;
293
- }
294
-
295
- hoveredNode = null;
296
- for (let i = nodes.length - 1; i >= 0; i--) {
297
- const n = nodes[i];
298
- const dx = mx - n.x;
299
- const dy = my - n.y;
300
- if (dx*dx + dy*dy < (n.radius + 5)**2) {
301
- hoveredNode = n;
302
- break;
303
- }
304
- }
305
- canvas.style.cursor = hoveredNode ? 'pointer' : 'default';
306
- });
307
-
308
- canvas.addEventListener('mousedown', e => {
309
- if (hoveredNode) {
310
- selectedNode = hoveredNode;
311
- isDragging = true;
312
- showDetails(selectedNode);
313
- } else {
314
- selectedNode = null;
315
- document.getElementById('node-details').style.display = 'none';
316
- }
317
- });
318
-
319
- canvas.addEventListener('mouseup', () => { isDragging = false; });
320
-
321
- function showDetails(n) {
322
- const panel = document.getElementById('node-details');
323
- panel.style.display = 'block';
324
- document.getElementById('nd-title').innerText = n.id;
325
-
326
- const riskEl = document.getElementById('nd-risk');
327
- riskEl.innerText = n.riskScore;
328
- riskEl.style.backgroundColor = n.color;
329
-
330
- document.getElementById('nd-blast').innerText = n.blastRadius;
331
-
332
- const importsUl = document.getElementById('nd-imports');
333
- importsUl.innerHTML = '';
334
- n.imports.forEach(i => {
335
- const li = document.createElement('li');
336
- li.innerText = i;
337
- importsUl.appendChild(li);
338
- });
339
- if(n.imports.length===0) importsUl.innerHTML = '<li>None</li>';
340
-
341
- const depsUl = document.getElementById('nd-dependents');
342
- depsUl.innerHTML = '';
343
- n.dependents.forEach(d => {
344
- const li = document.createElement('li');
345
- li.innerText = d;
346
- depsUl.appendChild(li);
347
- });
348
- if(n.dependents.length===0) depsUl.innerHTML = '<li>None</li>';
349
- }
350
- </script>
351
- </body>
352
- </html>