genoma-evolution 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (445) hide show
  1. package/.brv/.obsidian/app.json +1 -0
  2. package/.brv/.obsidian/appearance.json +1 -0
  3. package/.brv/.obsidian/core-plugins.json +33 -0
  4. package/.brv/.obsidian/graph.json +22 -0
  5. package/.brv/.obsidian/workspace.json +195 -0
  6. package/.brv/Sin ti/314/201tulo 1.canvas" +1 -0
  7. package/.brv/Sin ti/314/201tulo 2.canvas" +1 -0
  8. package/.brv/Sin ti/314/201tulo.canvas" +1 -0
  9. package/.brv/_queue_status.json +1 -0
  10. package/.brv/config.json +5 -0
  11. package/.brv/context-tree/_index.md +60 -0
  12. package/.brv/context-tree/_manifest.json +165 -0
  13. package/.brv/context-tree/backend/_index.md +24 -0
  14. package/.brv/context-tree/backend/backend/_index.md +40 -0
  15. package/.brv/context-tree/backend/backend/init.abstract.md +0 -0
  16. package/.brv/context-tree/backend/backend/init.md +27 -0
  17. package/.brv/context-tree/backend/backend/init.overview.md +29 -0
  18. package/.brv/context-tree/backend/backend/job_tracker.abstract.md +1 -0
  19. package/.brv/context-tree/backend/backend/job_tracker.md +273 -0
  20. package/.brv/context-tree/backend/backend/job_tracker.overview.md +31 -0
  21. package/.brv/context-tree/backend/backend/main.abstract.md +0 -0
  22. package/.brv/context-tree/backend/backend/main.md +1292 -0
  23. package/.brv/context-tree/backend/backend/main.overview.md +30 -0
  24. package/.brv/context-tree/backend/backend/requirements.abstract.md +1 -0
  25. package/.brv/context-tree/backend/backend/requirements.md +37 -0
  26. package/.brv/context-tree/backend/backend/requirements.overview.md +28 -0
  27. package/.brv/context-tree/docs/_index.md +37 -0
  28. package/.brv/context-tree/docs/api/_index.md +54 -0
  29. package/.brv/context-tree/docs/api/context.md +11 -0
  30. package/.brv/context-tree/docs/api/hermes_api_openapi_specification.abstract.md +0 -0
  31. package/.brv/context-tree/docs/api/hermes_api_openapi_specification.md +468 -0
  32. package/.brv/context-tree/docs/api/hermes_api_openapi_specification.overview.md +44 -0
  33. package/.brv/context-tree/frontend/_index.md +48 -0
  34. package/.brv/context-tree/frontend/hermes_dashboard/_index.md +31 -0
  35. package/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.abstract.md +0 -0
  36. package/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.md +41 -0
  37. package/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.overview.md +34 -0
  38. package/.brv/context-tree/frontend/src/_index.md +53 -0
  39. package/.brv/context-tree/frontend/src/components/_index.md +52 -0
  40. package/.brv/context-tree/frontend/src/components/sidebar_navigation_component.abstract.md +0 -0
  41. package/.brv/context-tree/frontend/src/components/sidebar_navigation_component.md +161 -0
  42. package/.brv/context-tree/frontend/src/components/sidebar_navigation_component.overview.md +32 -0
  43. package/.brv/context-tree/frontend/src/context.md +10 -0
  44. package/.brv/context-tree/frontend/src/functioncallingpage.abstract.md +0 -0
  45. package/.brv/context-tree/frontend/src/functioncallingpage.md +34 -0
  46. package/.brv/context-tree/frontend/src/functioncallingpage.overview.md +26 -0
  47. package/.brv/context-tree/frontend/src/lib/_index.md +48 -0
  48. package/.brv/context-tree/frontend/src/lib/api_client_library.abstract.md +1 -0
  49. package/.brv/context-tree/frontend/src/lib/api_client_library.md +403 -0
  50. package/.brv/context-tree/frontend/src/lib/api_client_library.overview.md +69 -0
  51. package/.brv/context-tree/frontend/src/page.abstract.md +0 -0
  52. package/.brv/context-tree/frontend/src/page.md +103 -0
  53. package/.brv/context-tree/frontend/src/page.overview.md +7 -0
  54. package/.brv/context-tree/frontend/src/settingspage.abstract.md +0 -0
  55. package/.brv/context-tree/frontend/src/settingspage.md +124 -0
  56. package/.brv/context-tree/frontend/src/settingspage.overview.md +34 -0
  57. package/.brv/context-tree/frontend/src/sidebar.abstract.md +0 -0
  58. package/.brv/context-tree/frontend/src/sidebar.md +170 -0
  59. package/.brv/context-tree/frontend/src/sidebar.overview.md +25 -0
  60. package/.brv/context-tree/meta/_index.md +24 -0
  61. package/.brv/context-tree/meta/curation_context/_index.md +24 -0
  62. package/.brv/context-tree/meta/curation_context/empty_context.abstract.md +4 -0
  63. package/.brv/context-tree/meta/curation_context/empty_context.md +35 -0
  64. package/.brv/context-tree/meta/curation_context/empty_context.overview.md +20 -0
  65. package/.brv/dream-log/drm-1777341062653.json +33 -0
  66. package/.brv/dream-state.json +8 -0
  67. package/.brv/dream.lock +0 -0
  68. package/.brv/review-backups/docs/api/hermes_api_openapi_specification.md +468 -0
  69. package/.claude/settings.local.json +7 -0
  70. package/.claude/worktrees/phase-2-mcp/.brv/.obsidian/app.json +1 -0
  71. package/.claude/worktrees/phase-2-mcp/.brv/.obsidian/appearance.json +1 -0
  72. package/.claude/worktrees/phase-2-mcp/.brv/.obsidian/core-plugins.json +33 -0
  73. package/.claude/worktrees/phase-2-mcp/.brv/.obsidian/graph.json +22 -0
  74. package/.claude/worktrees/phase-2-mcp/.brv/.obsidian/workspace.json +195 -0
  75. package/.claude/worktrees/phase-2-mcp/.brv/Sin t/303/255tulo 1.canvas" +1 -0
  76. package/.claude/worktrees/phase-2-mcp/.brv/Sin t/303/255tulo 2.canvas" +1 -0
  77. package/.claude/worktrees/phase-2-mcp/.brv/Sin t/303/255tulo.canvas" +1 -0
  78. package/.claude/worktrees/phase-2-mcp/.brv/_queue_status.json +1 -0
  79. package/.claude/worktrees/phase-2-mcp/.brv/config.json +5 -0
  80. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/_index.md +60 -0
  81. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/_manifest.json +165 -0
  82. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/_index.md +24 -0
  83. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/_index.md +40 -0
  84. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/init.abstract.md +0 -0
  85. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/init.md +27 -0
  86. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/init.overview.md +29 -0
  87. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/job_tracker.abstract.md +1 -0
  88. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/job_tracker.md +273 -0
  89. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/job_tracker.overview.md +31 -0
  90. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/main.abstract.md +0 -0
  91. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/main.md +1292 -0
  92. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/main.overview.md +30 -0
  93. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/requirements.abstract.md +1 -0
  94. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/requirements.md +37 -0
  95. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/backend/backend/requirements.overview.md +28 -0
  96. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/_index.md +37 -0
  97. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/api/_index.md +54 -0
  98. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/api/context.md +11 -0
  99. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/api/hermes_api_openapi_specification.abstract.md +0 -0
  100. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/api/hermes_api_openapi_specification.md +468 -0
  101. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/docs/api/hermes_api_openapi_specification.overview.md +44 -0
  102. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/_index.md +48 -0
  103. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/hermes_dashboard/_index.md +31 -0
  104. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.abstract.md +0 -0
  105. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.md +41 -0
  106. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/hermes_dashboard/architecture_overview.overview.md +34 -0
  107. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/_index.md +53 -0
  108. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/components/_index.md +52 -0
  109. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/components/sidebar_navigation_component.abstract.md +0 -0
  110. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/components/sidebar_navigation_component.md +161 -0
  111. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/components/sidebar_navigation_component.overview.md +32 -0
  112. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/context.md +10 -0
  113. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/functioncallingpage.abstract.md +0 -0
  114. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/functioncallingpage.md +34 -0
  115. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/functioncallingpage.overview.md +26 -0
  116. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/lib/_index.md +48 -0
  117. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/lib/api_client_library.abstract.md +1 -0
  118. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/lib/api_client_library.md +403 -0
  119. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/lib/api_client_library.overview.md +69 -0
  120. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/page.abstract.md +0 -0
  121. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/page.md +103 -0
  122. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/page.overview.md +7 -0
  123. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/settingspage.abstract.md +0 -0
  124. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/settingspage.md +124 -0
  125. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/settingspage.overview.md +34 -0
  126. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/sidebar.abstract.md +0 -0
  127. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/sidebar.md +170 -0
  128. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/frontend/src/sidebar.overview.md +25 -0
  129. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/meta/_index.md +24 -0
  130. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/meta/curation_context/_index.md +24 -0
  131. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/meta/curation_context/empty_context.abstract.md +4 -0
  132. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/meta/curation_context/empty_context.md +35 -0
  133. package/.claude/worktrees/phase-2-mcp/.brv/context-tree/meta/curation_context/empty_context.overview.md +20 -0
  134. package/.claude/worktrees/phase-2-mcp/.brv/dream-log/drm-1777341062653.json +33 -0
  135. package/.claude/worktrees/phase-2-mcp/.brv/dream-state.json +8 -0
  136. package/.claude/worktrees/phase-2-mcp/.brv/dream.lock +0 -0
  137. package/.claude/worktrees/phase-2-mcp/.brv/review-backups/docs/api/hermes_api_openapi_specification.md +468 -0
  138. package/.claude/worktrees/phase-2-mcp/.claude/settings.local.json +13 -0
  139. package/.claude/worktrees/phase-2-mcp/.kilocode/package-lock.json +378 -0
  140. package/.claude/worktrees/phase-2-mcp/.kilocode/package.json +5 -0
  141. package/.claude/worktrees/phase-2-mcp/AGENTS.md +5 -0
  142. package/.claude/worktrees/phase-2-mcp/CLAUDE.md +29 -0
  143. package/.claude/worktrees/phase-2-mcp/QA_AUDIT_PLAN.md +156 -0
  144. package/.claude/worktrees/phase-2-mcp/README.md +316 -0
  145. package/.claude/worktrees/phase-2-mcp/agent-agnostic-evolution-dashboard.md +405 -0
  146. package/.claude/worktrees/phase-2-mcp/backend/__init__.py +0 -0
  147. package/.claude/worktrees/phase-2-mcp/backend/collectors/__init__.py +0 -0
  148. package/.claude/worktrees/phase-2-mcp/backend/collectors/claude_code_collector.py +277 -0
  149. package/.claude/worktrees/phase-2-mcp/backend/collectors/hermes_collector.py +68 -0
  150. package/.claude/worktrees/phase-2-mcp/backend/curator.py +512 -0
  151. package/.claude/worktrees/phase-2-mcp/backend/eval/__init__.py +19 -0
  152. package/.claude/worktrees/phase-2-mcp/backend/eval/engine.py +116 -0
  153. package/.claude/worktrees/phase-2-mcp/backend/eval/scorers.py +201 -0
  154. package/.claude/worktrees/phase-2-mcp/backend/generate_dataset.py +86 -0
  155. package/.claude/worktrees/phase-2-mcp/backend/job_tracker.py +232 -0
  156. package/.claude/worktrees/phase-2-mcp/backend/main.py +1746 -0
  157. package/.claude/worktrees/phase-2-mcp/backend/mcp_server.py +250 -0
  158. package/.claude/worktrees/phase-2-mcp/backend/promethean/__init__.py +24 -0
  159. package/.claude/worktrees/phase-2-mcp/backend/promethean/cycle_orchestrator.py +270 -0
  160. package/.claude/worktrees/phase-2-mcp/backend/promethean/delta_validator.py +191 -0
  161. package/.claude/worktrees/phase-2-mcp/backend/promethean/dspy_compiler.py +315 -0
  162. package/.claude/worktrees/phase-2-mcp/backend/promethean/gepa_strategist.py +213 -0
  163. package/.claude/worktrees/phase-2-mcp/backend/promethean/models.py +260 -0
  164. package/.claude/worktrees/phase-2-mcp/backend/promethean/skill_deployer.py +195 -0
  165. package/.claude/worktrees/phase-2-mcp/backend/promethean/trace_ingestion.py +142 -0
  166. package/.claude/worktrees/phase-2-mcp/backend/requirements.txt +6 -0
  167. package/.claude/worktrees/phase-2-mcp/backend/sdd_evolve.py +459 -0
  168. package/.claude/worktrees/phase-2-mcp/backend/skill_detector.py +227 -0
  169. package/.claude/worktrees/phase-2-mcp/backend/skill_registry.py +289 -0
  170. package/.claude/worktrees/phase-2-mcp/backend/storage/__init__.py +5 -0
  171. package/.claude/worktrees/phase-2-mcp/backend/storage/run_store.py +393 -0
  172. package/.claude/worktrees/phase-2-mcp/backend/storage/schema.sql +99 -0
  173. package/.claude/worktrees/phase-2-mcp/backend/validate_evolution.py +267 -0
  174. package/.claude/worktrees/phase-2-mcp/components.json +28 -0
  175. package/.claude/worktrees/phase-2-mcp/docs/api/hermes-api.openapi.yaml +438 -0
  176. package/.claude/worktrees/phase-2-mcp/docs/hero.svg +148 -0
  177. package/.claude/worktrees/phase-2-mcp/eslint.config.mjs +18 -0
  178. package/.claude/worktrees/phase-2-mcp/install.sh +245 -0
  179. package/.claude/worktrees/phase-2-mcp/next-env.d.ts +6 -0
  180. package/.claude/worktrees/phase-2-mcp/next.config.ts +32 -0
  181. package/.claude/worktrees/phase-2-mcp/package-lock.json +11936 -0
  182. package/.claude/worktrees/phase-2-mcp/package.json +41 -0
  183. package/.claude/worktrees/phase-2-mcp/pnpm-workspace.yaml +4 -0
  184. package/.claude/worktrees/phase-2-mcp/postcss.config.mjs +7 -0
  185. package/.claude/worktrees/phase-2-mcp/public/file.svg +1 -0
  186. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Display-Bold.otf +0 -0
  187. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Display-Heavy.otf +0 -0
  188. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Display-Medium.otf +0 -0
  189. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Display-Regular.otf +0 -0
  190. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Display-Semibold.otf +0 -0
  191. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Text-Bold.otf +0 -0
  192. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Text-Heavy.otf +0 -0
  193. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Text-Medium.otf +0 -0
  194. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Text-Regular.otf +0 -0
  195. package/.claude/worktrees/phase-2-mcp/public/fonts/SF-Pro-Text-Semibold.otf +0 -0
  196. package/.claude/worktrees/phase-2-mcp/public/globe.svg +1 -0
  197. package/.claude/worktrees/phase-2-mcp/public/next.svg +1 -0
  198. package/.claude/worktrees/phase-2-mcp/public/theme-preview.html +257 -0
  199. package/.claude/worktrees/phase-2-mcp/public/vercel.svg +1 -0
  200. package/.claude/worktrees/phase-2-mcp/public/window.svg +1 -0
  201. package/.claude/worktrees/phase-2-mcp/run.sh +26 -0
  202. package/.claude/worktrees/phase-2-mcp/skills-lock.json +10 -0
  203. package/.claude/worktrees/phase-2-mcp/specs/event-schema.md +223 -0
  204. package/.claude/worktrees/phase-2-mcp/specs/examples/run.jsonl +3 -0
  205. package/.claude/worktrees/phase-2-mcp/src/app/api/[...path]/route.ts +55 -0
  206. package/.claude/worktrees/phase-2-mcp/src/app/api/auth/token/route.ts +22 -0
  207. package/.claude/worktrees/phase-2-mcp/src/app/evolution/page.tsx +589 -0
  208. package/.claude/worktrees/phase-2-mcp/src/app/favicon.ico +0 -0
  209. package/.claude/worktrees/phase-2-mcp/src/app/globals.css +321 -0
  210. package/.claude/worktrees/phase-2-mcp/src/app/layout.tsx +63 -0
  211. package/.claude/worktrees/phase-2-mcp/src/app/page.tsx +70 -0
  212. package/.claude/worktrees/phase-2-mcp/src/app/skills/page.tsx +369 -0
  213. package/.claude/worktrees/phase-2-mcp/src/components/ApiConfigCard.tsx +199 -0
  214. package/.claude/worktrees/phase-2-mcp/src/components/ColorBends.css +1 -0
  215. package/.claude/worktrees/phase-2-mcp/src/components/ColorBends.d.ts +1 -0
  216. package/.claude/worktrees/phase-2-mcp/src/components/ColorBends.jsx +1 -0
  217. package/.claude/worktrees/phase-2-mcp/src/components/CoreLoopToggle.tsx +111 -0
  218. package/.claude/worktrees/phase-2-mcp/src/components/EnvironmentStatus.tsx +176 -0
  219. package/.claude/worktrees/phase-2-mcp/src/components/EvolutionBackground.tsx +1 -0
  220. package/.claude/worktrees/phase-2-mcp/src/components/ReactQueryProvider.tsx +24 -0
  221. package/.claude/worktrees/phase-2-mcp/src/components/Sidebar.tsx +247 -0
  222. package/.claude/worktrees/phase-2-mcp/src/components/SkillDiffViewer.tsx +154 -0
  223. package/.claude/worktrees/phase-2-mcp/src/components/ThemeAwareBackground.tsx +67 -0
  224. package/.claude/worktrees/phase-2-mcp/src/components/ThemeToggle.tsx +54 -0
  225. package/.claude/worktrees/phase-2-mcp/src/components/WelcomeHero.tsx +77 -0
  226. package/.claude/worktrees/phase-2-mcp/src/components/bits/ClickSpark.tsx +116 -0
  227. package/.claude/worktrees/phase-2-mcp/src/components/bits/CountUp.tsx +98 -0
  228. package/.claude/worktrees/phase-2-mcp/src/components/bits/DarkSelect.tsx +95 -0
  229. package/.claude/worktrees/phase-2-mcp/src/components/bits/DecryptedText.tsx +161 -0
  230. package/.claude/worktrees/phase-2-mcp/src/components/bits/ElectricBorder.tsx +184 -0
  231. package/.claude/worktrees/phase-2-mcp/src/components/bits/GlitchText.tsx +34 -0
  232. package/.claude/worktrees/phase-2-mcp/src/components/bits/ShinyText.tsx +55 -0
  233. package/.claude/worktrees/phase-2-mcp/src/components/bits/SpotlightCard.tsx +42 -0
  234. package/.claude/worktrees/phase-2-mcp/src/components/bits/TextType.tsx +95 -0
  235. package/.claude/worktrees/phase-2-mcp/src/components/bits/index.ts +9 -0
  236. package/.claude/worktrees/phase-2-mcp/src/components/pages/CuratorPage.tsx +632 -0
  237. package/.claude/worktrees/phase-2-mcp/src/components/pages/DatasetPage.tsx +271 -0
  238. package/.claude/worktrees/phase-2-mcp/src/components/pages/EvolutionPage.tsx +676 -0
  239. package/.claude/worktrees/phase-2-mcp/src/components/pages/FunctionCallingPage.tsx +1 -0
  240. package/.claude/worktrees/phase-2-mcp/src/components/pages/LogsPage.tsx +272 -0
  241. package/.claude/worktrees/phase-2-mcp/src/components/pages/MetricsPage.tsx +246 -0
  242. package/.claude/worktrees/phase-2-mcp/src/components/pages/OverviewPage.tsx +420 -0
  243. package/.claude/worktrees/phase-2-mcp/src/components/pages/SettingsPage.tsx +88 -0
  244. package/.claude/worktrees/phase-2-mcp/src/components/pages/SkillStudioPage.tsx +376 -0
  245. package/.claude/worktrees/phase-2-mcp/src/components/ui/animated-theme-toggler.tsx +97 -0
  246. package/.claude/worktrees/phase-2-mcp/src/components/ui/button.tsx +67 -0
  247. package/.claude/worktrees/phase-2-mcp/src/components/ui/card.tsx +103 -0
  248. package/.claude/worktrees/phase-2-mcp/src/components/ui/input.tsx +19 -0
  249. package/.claude/worktrees/phase-2-mcp/src/components/ui/separator.tsx +28 -0
  250. package/.claude/worktrees/phase-2-mcp/src/components/ui/sheet.tsx +147 -0
  251. package/.claude/worktrees/phase-2-mcp/src/components/ui/sidebar.tsx +702 -0
  252. package/.claude/worktrees/phase-2-mcp/src/components/ui/skeleton.tsx +13 -0
  253. package/.claude/worktrees/phase-2-mcp/src/components/ui/theme-toggle.tsx +272 -0
  254. package/.claude/worktrees/phase-2-mcp/src/components/ui/tooltip.tsx +57 -0
  255. package/.claude/worktrees/phase-2-mcp/src/hooks/use-mobile.ts +19 -0
  256. package/.claude/worktrees/phase-2-mcp/src/lib/api.ts +455 -0
  257. package/.claude/worktrees/phase-2-mcp/src/lib/queryClient.ts +12 -0
  258. package/.claude/worktrees/phase-2-mcp/src/lib/utils.ts +6 -0
  259. package/.claude/worktrees/phase-2-mcp/stitch/agent_dashboard/DESIGN_SPEC.md +521 -0
  260. package/.claude/worktrees/phase-2-mcp/stitch/agent_dashboard/prototype.html +676 -0
  261. package/.claude/worktrees/phase-2-mcp/stitch/curator_workspace/code.html +448 -0
  262. package/.claude/worktrees/phase-2-mcp/stitch/curator_workspace/screen.png +0 -0
  263. package/.claude/worktrees/phase-2-mcp/stitch/datasets/code.html +479 -0
  264. package/.claude/worktrees/phase-2-mcp/stitch/datasets/screen.png +0 -0
  265. package/.claude/worktrees/phase-2-mcp/stitch/evolution_history/code.html +461 -0
  266. package/.claude/worktrees/phase-2-mcp/stitch/evolution_history/screen.png +0 -0
  267. package/.claude/worktrees/phase-2-mcp/stitch/hermes_dashboard/DESIGN.md +192 -0
  268. package/.claude/worktrees/phase-2-mcp/stitch/hermes_dashboard/DESIGN_SPEC.md +455 -0
  269. package/.claude/worktrees/phase-2-mcp/stitch/hermes_overview/code.html +399 -0
  270. package/.claude/worktrees/phase-2-mcp/stitch/hermes_overview/screen.png +0 -0
  271. package/.claude/worktrees/phase-2-mcp/stitch/live_logs/code.html +324 -0
  272. package/.claude/worktrees/phase-2-mcp/stitch/live_logs/screen.png +0 -0
  273. package/.claude/worktrees/phase-2-mcp/stitch/skill_hub/code.html +596 -0
  274. package/.claude/worktrees/phase-2-mcp/stitch/skill_hub/screen.png +0 -0
  275. package/.claude/worktrees/phase-2-mcp/stitch/system_metrics/code.html +527 -0
  276. package/.claude/worktrees/phase-2-mcp/stitch/system_metrics/screen.png +0 -0
  277. package/.claude/worktrees/phase-2-mcp/stitch/system_settings/code.html +257 -0
  278. package/.claude/worktrees/phase-2-mcp/stitch/system_settings/screen.png +0 -0
  279. package/.claude/worktrees/phase-2-mcp/test_dashboard.py +201 -0
  280. package/.claude/worktrees/phase-2-mcp/tests/collectors/__init__.py +0 -0
  281. package/.claude/worktrees/phase-2-mcp/tests/collectors/fixtures/sample_session.jsonl +7 -0
  282. package/.claude/worktrees/phase-2-mcp/tests/collectors/test_claude_code_collector.py +171 -0
  283. package/.claude/worktrees/phase-2-mcp/tests/collectors/test_hermes_collector.py +167 -0
  284. package/.claude/worktrees/phase-2-mcp/tests/eval/test_engine.py +234 -0
  285. package/.claude/worktrees/phase-2-mcp/tests/eval/test_scorers.py +249 -0
  286. package/.claude/worktrees/phase-2-mcp/tests/storage/__init__.py +0 -0
  287. package/.claude/worktrees/phase-2-mcp/tests/storage/test_run_store.py +359 -0
  288. package/.claude/worktrees/phase-2-mcp/tests/test_curator.py +559 -0
  289. package/.claude/worktrees/phase-2-mcp/tests/test_mcp_server.py +114 -0
  290. package/.claude/worktrees/phase-2-mcp/tsconfig.json +34 -0
  291. package/.env.example +72 -0
  292. package/.kilocode/package-lock.json +378 -0
  293. package/.kilocode/package.json +5 -0
  294. package/AGENTS.md +5 -0
  295. package/CLAUDE.md +29 -0
  296. package/QA_AUDIT_PLAN.md +156 -0
  297. package/README.md +355 -0
  298. package/agent-agnostic-evolution-dashboard.md +405 -0
  299. package/backend/__init__.py +0 -0
  300. package/backend/collectors/__init__.py +0 -0
  301. package/backend/collectors/claude_code_collector.py +277 -0
  302. package/backend/collectors/hermes_collector.py +68 -0
  303. package/backend/curator.py +512 -0
  304. package/backend/eval/__init__.py +19 -0
  305. package/backend/eval/engine.py +116 -0
  306. package/backend/eval/scorers.py +201 -0
  307. package/backend/generate_dataset.py +86 -0
  308. package/backend/job_tracker.py +232 -0
  309. package/backend/main.py +1746 -0
  310. package/backend/mcp_server.py +250 -0
  311. package/backend/promethean/__init__.py +24 -0
  312. package/backend/promethean/cycle_orchestrator.py +270 -0
  313. package/backend/promethean/delta_validator.py +191 -0
  314. package/backend/promethean/dspy_compiler.py +315 -0
  315. package/backend/promethean/gepa_strategist.py +213 -0
  316. package/backend/promethean/models.py +260 -0
  317. package/backend/promethean/skill_deployer.py +195 -0
  318. package/backend/promethean/trace_ingestion.py +142 -0
  319. package/backend/requirements.txt +6 -0
  320. package/backend/sdd_evolve.py +459 -0
  321. package/backend/skill_detector.py +227 -0
  322. package/backend/skill_registry.py +289 -0
  323. package/backend/storage/__init__.py +5 -0
  324. package/backend/storage/run_store.py +393 -0
  325. package/backend/storage/schema.sql +99 -0
  326. package/backend/validate_evolution.py +267 -0
  327. package/bin/genoma.js +250 -0
  328. package/components.json +28 -0
  329. package/docs/api/hermes-api.openapi.yaml +438 -0
  330. package/docs/hero.svg +148 -0
  331. package/eslint.config.mjs +18 -0
  332. package/install.sh +245 -0
  333. package/next-env.d.ts +6 -0
  334. package/next.config.ts +32 -0
  335. package/package.json +46 -0
  336. package/pnpm-workspace.yaml +4 -0
  337. package/postcss.config.mjs +7 -0
  338. package/public/file.svg +1 -0
  339. package/public/fonts/SF-Pro-Display-Bold.otf +0 -0
  340. package/public/fonts/SF-Pro-Display-Heavy.otf +0 -0
  341. package/public/fonts/SF-Pro-Display-Medium.otf +0 -0
  342. package/public/fonts/SF-Pro-Display-Regular.otf +0 -0
  343. package/public/fonts/SF-Pro-Display-Semibold.otf +0 -0
  344. package/public/fonts/SF-Pro-Text-Bold.otf +0 -0
  345. package/public/fonts/SF-Pro-Text-Heavy.otf +0 -0
  346. package/public/fonts/SF-Pro-Text-Medium.otf +0 -0
  347. package/public/fonts/SF-Pro-Text-Regular.otf +0 -0
  348. package/public/fonts/SF-Pro-Text-Semibold.otf +0 -0
  349. package/public/globe.svg +1 -0
  350. package/public/next.svg +1 -0
  351. package/public/theme-preview.html +257 -0
  352. package/public/vercel.svg +1 -0
  353. package/public/window.svg +1 -0
  354. package/run.sh +26 -0
  355. package/scripts/postinstall.js +50 -0
  356. package/skills-lock.json +10 -0
  357. package/specs/event-schema.md +223 -0
  358. package/specs/examples/run.jsonl +3 -0
  359. package/src/app/api/[...path]/route.ts +55 -0
  360. package/src/app/api/auth/token/route.ts +22 -0
  361. package/src/app/evolution/page.tsx +589 -0
  362. package/src/app/favicon.ico +0 -0
  363. package/src/app/globals.css +321 -0
  364. package/src/app/layout.tsx +63 -0
  365. package/src/app/page.tsx +70 -0
  366. package/src/app/skills/page.tsx +369 -0
  367. package/src/components/ApiConfigCard.tsx +199 -0
  368. package/src/components/ColorBends.css +1 -0
  369. package/src/components/ColorBends.d.ts +1 -0
  370. package/src/components/ColorBends.jsx +1 -0
  371. package/src/components/CoreLoopToggle.tsx +111 -0
  372. package/src/components/EnvironmentStatus.tsx +176 -0
  373. package/src/components/EvolutionBackground.tsx +1 -0
  374. package/src/components/ReactQueryProvider.tsx +24 -0
  375. package/src/components/Sidebar.tsx +247 -0
  376. package/src/components/SkillDiffViewer.tsx +154 -0
  377. package/src/components/ThemeAwareBackground.tsx +67 -0
  378. package/src/components/ThemeToggle.tsx +54 -0
  379. package/src/components/WelcomeHero.tsx +77 -0
  380. package/src/components/bits/ClickSpark.tsx +116 -0
  381. package/src/components/bits/CountUp.tsx +98 -0
  382. package/src/components/bits/DarkSelect.tsx +95 -0
  383. package/src/components/bits/DecryptedText.tsx +161 -0
  384. package/src/components/bits/ElectricBorder.tsx +184 -0
  385. package/src/components/bits/GlitchText.tsx +34 -0
  386. package/src/components/bits/ShinyText.tsx +55 -0
  387. package/src/components/bits/SpotlightCard.tsx +42 -0
  388. package/src/components/bits/TextType.tsx +95 -0
  389. package/src/components/bits/index.ts +9 -0
  390. package/src/components/pages/CuratorPage.tsx +632 -0
  391. package/src/components/pages/DatasetPage.tsx +271 -0
  392. package/src/components/pages/EvolutionPage.tsx +676 -0
  393. package/src/components/pages/FunctionCallingPage.tsx +1 -0
  394. package/src/components/pages/LogsPage.tsx +272 -0
  395. package/src/components/pages/MetricsPage.tsx +246 -0
  396. package/src/components/pages/OverviewPage.tsx +420 -0
  397. package/src/components/pages/SettingsPage.tsx +88 -0
  398. package/src/components/pages/SkillStudioPage.tsx +376 -0
  399. package/src/components/ui/animated-theme-toggler.tsx +97 -0
  400. package/src/components/ui/button.tsx +67 -0
  401. package/src/components/ui/card.tsx +103 -0
  402. package/src/components/ui/input.tsx +19 -0
  403. package/src/components/ui/separator.tsx +28 -0
  404. package/src/components/ui/sheet.tsx +147 -0
  405. package/src/components/ui/sidebar.tsx +702 -0
  406. package/src/components/ui/skeleton.tsx +13 -0
  407. package/src/components/ui/theme-toggle.tsx +272 -0
  408. package/src/components/ui/tooltip.tsx +57 -0
  409. package/src/hooks/use-mobile.ts +19 -0
  410. package/src/lib/api.ts +455 -0
  411. package/src/lib/queryClient.ts +12 -0
  412. package/src/lib/utils.ts +6 -0
  413. package/stitch/agent_dashboard/DESIGN_SPEC.md +521 -0
  414. package/stitch/agent_dashboard/prototype.html +676 -0
  415. package/stitch/curator_workspace/code.html +448 -0
  416. package/stitch/curator_workspace/screen.png +0 -0
  417. package/stitch/datasets/code.html +479 -0
  418. package/stitch/datasets/screen.png +0 -0
  419. package/stitch/evolution_history/code.html +461 -0
  420. package/stitch/evolution_history/screen.png +0 -0
  421. package/stitch/hermes_dashboard/DESIGN.md +192 -0
  422. package/stitch/hermes_dashboard/DESIGN_SPEC.md +455 -0
  423. package/stitch/hermes_overview/code.html +399 -0
  424. package/stitch/hermes_overview/screen.png +0 -0
  425. package/stitch/live_logs/code.html +324 -0
  426. package/stitch/live_logs/screen.png +0 -0
  427. package/stitch/skill_hub/code.html +596 -0
  428. package/stitch/skill_hub/screen.png +0 -0
  429. package/stitch/system_metrics/code.html +527 -0
  430. package/stitch/system_metrics/screen.png +0 -0
  431. package/stitch/system_settings/code.html +257 -0
  432. package/stitch/system_settings/screen.png +0 -0
  433. package/test_dashboard.py +201 -0
  434. package/tests/collectors/__init__.py +0 -0
  435. package/tests/collectors/fixtures/sample_session.jsonl +7 -0
  436. package/tests/collectors/test_claude_code_collector.py +171 -0
  437. package/tests/collectors/test_hermes_collector.py +167 -0
  438. package/tests/eval/test_engine.py +234 -0
  439. package/tests/eval/test_scorers.py +249 -0
  440. package/tests/storage/__init__.py +0 -0
  441. package/tests/storage/test_run_store.py +359 -0
  442. package/tests/test_curator.py +559 -0
  443. package/tests/test_e2e_npm.py +621 -0
  444. package/tests/test_mcp_server.py +114 -0
  445. package/tsconfig.json +34 -0
@@ -0,0 +1,676 @@
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>GENOMA — Agent Evolution Dashboard</title>
7
+ <link rel="preconnect" href="https://fonts.googleapis.com">
8
+ <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap" rel="stylesheet">
9
+ <style>
10
+ :root {
11
+ --primary: #002444;
12
+ --primary-80: rgba(0,36,68,0.8);
13
+ --primary-10: rgba(0,36,68,0.1);
14
+ --primary-5: rgba(0,36,68,0.05);
15
+ --accent: #a93800;
16
+ --surface: #faf9fc;
17
+ --surface-low: #f4f3f6;
18
+ --surface-container: #eeedf1;
19
+ --on-surface: #1a1c1e;
20
+ --on-surface-variant: #43474e;
21
+ --outline: #73777f;
22
+ --outline-variant: #c3c6cf;
23
+ --success: #4caf50;
24
+ --success-bg: rgba(76,175,80,0.1);
25
+ --warning: #f59e0b;
26
+ --warning-bg: rgba(245,158,11,0.1);
27
+ --error: #ba1a1a;
28
+ --error-bg: rgba(186,26,26,0.1);
29
+ --neutral-bg: rgba(115,119,127,0.08);
30
+ }
31
+ * { box-sizing: border-box; margin: 0; padding: 0; }
32
+ body { font-family: 'Inter', sans-serif; background: var(--surface); color: var(--on-surface); font-size: 14px; line-height: 20px; }
33
+ .mono { font-family: 'JetBrains Mono', monospace; }
34
+
35
+ /* Header */
36
+ .header {
37
+ height: 56px; background: var(--primary); display: flex; align-items: center;
38
+ justify-content: space-between; padding: 0 24px; position: sticky; top: 0; z-index: 100;
39
+ }
40
+ .header-left { display: flex; align-items: center; gap: 12px; color: white; font-weight: 600; font-size: 16px; }
41
+ .header-logo { width: 28px; height: 28px; background: rgba(255,255,255,0.15); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 16px; }
42
+ .header-status { display: flex; align-items: center; gap: 6px; color: rgba(255,255,255,0.7); font-size: 13px; }
43
+ .status-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); box-shadow: 0 0 6px var(--success); }
44
+ .header-user { color: rgba(255,255,255,0.7); font-size: 13px; cursor: pointer; }
45
+
46
+ /* Tabs */
47
+ .tabs {
48
+ height: 48px; background: var(--surface); border-bottom: 1px solid var(--outline-variant);
49
+ display: flex; align-items: flex-end; padding: 0 24px; position: sticky; top: 56px; z-index: 99;
50
+ }
51
+ .tab { padding: 12px 16px; cursor: pointer; font-size: 14px; color: var(--outline); border-bottom: 3px solid transparent; transition: all 0.15s; margin-bottom: -1px; }
52
+ .tab:hover { color: var(--on-surface); }
53
+ .tab.active { color: var(--primary); font-weight: 600; border-bottom-color: var(--primary); }
54
+
55
+ /* Layout */
56
+ .layout { display: flex; min-height: calc(100vh - 104px); }
57
+ .sidebar { width: 256px; flex-shrink: 0; background: var(--surface); border-right: 1px solid var(--outline-variant); padding: 20px 16px; }
58
+ .main { flex: 1; padding: 24px; max-width: 1184px; }
59
+ .sidebar-section { margin-bottom: 24px; }
60
+ .sidebar-label { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; margin-bottom: 8px; }
61
+ .sidebar-item { padding: 8px 10px; border-radius: 4px; cursor: pointer; display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--on-surface-variant); transition: background 0.1s; }
62
+ .sidebar-item:hover { background: var(--surface-low); }
63
+ .sidebar-item.active { background: var(--primary-10); color: var(--primary); font-weight: 500; }
64
+ .agent-dot { width: 7px; height: 7px; border-radius: 50%; }
65
+
66
+ /* Page title */
67
+ .page-title { font-size: 20px; font-weight: 600; margin-bottom: 20px; }
68
+
69
+ /* Stat cards */
70
+ .stat-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
71
+ .stat-card { background: white; border: 1px solid var(--primary-10); border-radius: 8px; padding: 16px; }
72
+ .stat-label { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--on-surface-variant); text-transform: uppercase; margin-bottom: 8px; }
73
+ .stat-value { font-family: 'JetBrains Mono', monospace; font-size: 28px; font-weight: 500; color: var(--on-surface); line-height: 1; margin-bottom: 12px; }
74
+ .sparkline { height: 32px; background: linear-gradient(to right, var(--primary-10), var(--primary-5)); border-radius: 2px; position: relative; overflow: hidden; }
75
+ .sparkline-line { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: var(--primary); opacity: 0.4; }
76
+
77
+ /* Section header */
78
+ .section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
79
+ .section-title { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; }
80
+
81
+ /* Table */
82
+ .table-wrap { background: white; border: 1px solid var(--primary-10); border-radius: 8px; overflow: hidden; margin-bottom: 24px; }
83
+ table { width: 100%; border-collapse: collapse; }
84
+ thead tr { background: var(--surface-low); }
85
+ th { padding: 10px 16px; font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-align: left; text-transform: uppercase; }
86
+ td { padding: 0 16px; height: 40px; border-top: 1px solid var(--outline-variant); font-size: 13px; color: var(--on-surface); vertical-align: middle; }
87
+ tr:hover td { background: var(--surface-low); cursor: pointer; }
88
+ .td-mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--on-surface-variant); }
89
+
90
+ /* Pills */
91
+ .pill { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 4px; font-size: 12px; font-weight: 500; }
92
+ .pill-success { color: var(--success); background: var(--success-bg); }
93
+ .pill-failure { color: var(--error); background: var(--error-bg); }
94
+ .pill-partial { color: var(--warning); background: var(--warning-bg); }
95
+ .score-badge { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; padding: 2px 8px; border-radius: 4px; }
96
+ .score-high { background: var(--primary); color: white; }
97
+ .score-mid { background: var(--warning-bg); color: #92400e; }
98
+ .score-low { background: var(--error-bg); color: var(--error); }
99
+
100
+ /* Agent chip */
101
+ .agent-chip { display: inline-flex; align-items: center; gap: 5px; padding: 3px 8px; border-radius: 4px; border: 1px solid var(--outline-variant); font-size: 12px; color: var(--primary); }
102
+
103
+ /* Delta indicator */
104
+ .delta { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; }
105
+ .delta-pos { color: var(--success); }
106
+ .delta-neg { color: var(--error); }
107
+ .delta-neu { color: var(--outline); }
108
+
109
+ /* Filter bar */
110
+ .filter-bar { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
111
+ .filter-btn { padding: 6px 14px; border: 1px solid var(--outline-variant); border-radius: 4px; background: white; font-size: 13px; color: var(--on-surface); cursor: pointer; display: flex; align-items: center; gap: 6px; }
112
+ .filter-btn:hover { border-color: var(--primary); }
113
+ .filter-btn.active { background: var(--primary); color: white; border-color: var(--primary); }
114
+ .filter-spacer { flex: 1; }
115
+ .btn-secondary { padding: 6px 14px; border: 1px solid var(--primary); border-radius: 4px; background: white; font-size: 13px; color: var(--primary); cursor: pointer; }
116
+ .btn-primary { padding: 6px 14px; border: none; border-radius: 4px; background: var(--primary); font-size: 13px; color: white; cursor: pointer; }
117
+
118
+ /* Two-col */
119
+ .two-col { display: grid; grid-template-columns: 1fr 340px; gap: 24px; align-items: start; }
120
+
121
+ /* Score distribution */
122
+ .score-dist { background: white; border: 1px solid var(--primary-10); border-radius: 8px; padding: 16px; }
123
+ .bar-row { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
124
+ .bar-label { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--on-surface-variant); width: 90px; flex-shrink: 0; }
125
+ .bar-track { flex: 1; height: 8px; background: var(--surface-container); border-radius: 2px; overflow: hidden; }
126
+ .bar-fill { height: 100%; background: var(--primary); border-radius: 2px; }
127
+ .bar-value { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--on-surface); width: 32px; text-align: right; }
128
+ .dist-section { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; margin: 16px 0 10px; }
129
+
130
+ /* Drawer */
131
+ .drawer-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.2); z-index: 200; }
132
+ .drawer-overlay.open { display: block; }
133
+ .drawer { position: fixed; right: 0; top: 0; bottom: 0; width: 520px; background: white; box-shadow: -4px 0 24px rgba(0,0,0,0.1); z-index: 201; display: flex; flex-direction: column; transform: translateX(100%); transition: transform 0.25s ease-out; }
134
+ .drawer-overlay.open .drawer { transform: translateX(0); }
135
+ .drawer-head { padding: 20px 20px 16px; border-bottom: 1px solid var(--outline-variant); }
136
+ .drawer-run-id { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--outline); margin-bottom: 4px; }
137
+ .drawer-task { font-size: 18px; font-weight: 600; margin-bottom: 4px; }
138
+ .drawer-meta { font-size: 13px; color: var(--on-surface-variant); display: flex; align-items: center; gap: 12px; }
139
+ .drawer-close { position: absolute; top: 16px; right: 16px; width: 32px; height: 32px; border: none; background: var(--surface-low); border-radius: 4px; cursor: pointer; font-size: 16px; display: flex; align-items: center; justify-content: center; }
140
+ .drawer-body { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 20px; }
141
+ .drawer-section-title { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; margin-bottom: 12px; }
142
+ .agg-score-block { text-align: center; padding: 20px; background: var(--surface-low); border-radius: 8px; }
143
+ .agg-score-num { font-family: 'JetBrains Mono', monospace; font-size: 40px; font-weight: 500; color: var(--primary); line-height: 1; }
144
+ .score-bar { height: 8px; background: var(--surface-container); border-radius: 4px; margin-top: 12px; overflow: hidden; }
145
+ .score-bar-fill { height: 100%; background: var(--primary); border-radius: 4px; }
146
+ .breakdown-table { width: 100%; border-collapse: collapse; }
147
+ .breakdown-table th { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; padding: 6px 8px; text-align: left; }
148
+ .breakdown-table td { padding: 8px 8px; border-top: 1px solid var(--outline-variant); font-size: 13px; }
149
+ .breakdown-table tr.total td { background: var(--surface-low); font-weight: 600; }
150
+ .metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
151
+ .metric-row { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid var(--surface-low); }
152
+ .metric-key { font-size: 12px; color: var(--on-surface-variant); }
153
+ .metric-val { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--on-surface); }
154
+ .drawer-footer { padding: 16px 20px; border-top: 1px solid var(--outline-variant); display: flex; gap: 10px; }
155
+
156
+ /* Regression */
157
+ .regression-page { max-width: 900px; }
158
+ .run-selector { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 20px; }
159
+ .run-select-box { padding: 14px 16px; border: 1px solid var(--outline-variant); border-radius: 6px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; background: white; }
160
+ .run-select-label { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; color: var(--outline); text-transform: uppercase; margin-bottom: 6px; }
161
+ .run-select-id { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--primary); }
162
+ .run-select-task { font-size: 13px; color: var(--on-surface-variant); }
163
+ .delta-banner { padding: 14px 20px; border-radius: 6px; margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
164
+ .delta-banner.improvement { background: var(--success-bg); border: 1px solid var(--success); }
165
+ .delta-banner.regression { background: var(--error-bg); border: 1px solid var(--error); }
166
+ .delta-banner.neutral { background: var(--neutral-bg); border: 1px solid var(--outline-variant); }
167
+ .delta-banner-icon { font-size: 20px; }
168
+ .delta-banner-title { font-size: 14px; font-weight: 600; }
169
+ .delta-banner-sub { font-size: 13px; color: var(--on-surface-variant); }
170
+ .compare-table th, .compare-table td { padding: 10px 14px; border: 1px solid var(--outline-variant); font-size: 13px; }
171
+ .compare-table th { background: var(--surface-low); font-size: 11px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--outline); }
172
+ .compare-table td.delta-pos { color: var(--success); font-family: 'JetBrains Mono', monospace; font-weight: 500; }
173
+ .compare-table td.delta-neg { color: var(--error); font-family: 'JetBrains Mono', monospace; font-weight: 500; }
174
+ .compare-table td.delta-neu { color: var(--outline); font-family: 'JetBrains Mono', monospace; }
175
+ .compare-table tr.improved td:first-child { border-left: 3px solid var(--success); }
176
+ .compare-table tr.regressed td:first-child { border-left: 3px solid var(--error); }
177
+ .threshold-row { display: flex; align-items: center; gap: 16px; padding: 12px 0; }
178
+ .threshold-label { font-size: 13px; color: var(--on-surface-variant); width: 80px; }
179
+ input[type=range] { flex: 1; accent-color: var(--primary); }
180
+ .threshold-val { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--primary); width: 36px; }
181
+
182
+ /* Tab content */
183
+ .tab-content { display: none; }
184
+ .tab-content.active { display: block; }
185
+ </style>
186
+ </head>
187
+ <body>
188
+
189
+ <!-- Header -->
190
+ <div class="header">
191
+ <div class="header-left">
192
+ <div class="header-logo">⬡</div>
193
+ GENOMA
194
+ </div>
195
+ <div class="header-status">
196
+ <div class="status-dot"></div>
197
+ All Systems Active — last sync 3s ago
198
+ </div>
199
+ <div class="header-user">👤 Leandro</div>
200
+ </div>
201
+
202
+ <!-- Tabs -->
203
+ <div class="tabs">
204
+ <div class="tab active" onclick="showTab('agents')">Agents</div>
205
+ <div class="tab" onclick="showTab('runs')">Runs</div>
206
+ <div class="tab" onclick="showTab('regression')">Regression</div>
207
+ <div class="tab" onclick="showTab('scorers')">Scorers</div>
208
+ </div>
209
+
210
+ <div class="layout">
211
+ <!-- Sidebar -->
212
+ <div class="sidebar">
213
+ <div class="sidebar-section">
214
+ <div class="sidebar-label">Agents</div>
215
+ <div class="sidebar-item active">
216
+ <div class="agent-dot" style="background:#4caf50"></div>
217
+ hermes
218
+ </div>
219
+ <div class="sidebar-item">
220
+ <div class="agent-dot" style="background:#4caf50"></div>
221
+ claude-code
222
+ </div>
223
+ <div class="sidebar-item">
224
+ <div class="agent-dot" style="background:#73777f"></div>
225
+ codex
226
+ </div>
227
+ </div>
228
+ <div class="sidebar-section">
229
+ <div class="sidebar-label">Quick Stats</div>
230
+ <div style="padding:8px 10px; font-size:12px; color:var(--on-surface-variant); line-height:22px;">
231
+ <div style="display:flex;justify-content:space-between"><span>Total runs</span><span class="mono">1,247</span></div>
232
+ <div style="display:flex;justify-content:space-between"><span>Avg success</span><span class="mono" style="color:var(--success)">87.4%</span></div>
233
+ <div style="display:flex;justify-content:space-between"><span>Avg score</span><span class="mono" style="color:var(--primary)">0.83</span></div>
234
+ </div>
235
+ </div>
236
+ </div>
237
+
238
+ <!-- Main -->
239
+ <div class="main">
240
+
241
+ <!-- ── AGENTS TAB ── -->
242
+ <div class="tab-content active" id="tab-agents">
243
+ <div class="page-title">Agent Overview</div>
244
+
245
+ <div class="stat-cards">
246
+ <div class="stat-card">
247
+ <div class="stat-label">Agents</div>
248
+ <div class="stat-value">3</div>
249
+ <div class="sparkline"><div class="sparkline-line"></div></div>
250
+ </div>
251
+ <div class="stat-card">
252
+ <div class="stat-label">Total Runs</div>
253
+ <div class="stat-value">1,247</div>
254
+ <div class="sparkline"><div class="sparkline-line"></div></div>
255
+ </div>
256
+ <div class="stat-card">
257
+ <div class="stat-label">Avg Success</div>
258
+ <div class="stat-value" style="color:var(--success)">87.4%</div>
259
+ <div class="sparkline"><div class="sparkline-line"></div></div>
260
+ </div>
261
+ <div class="stat-card">
262
+ <div class="stat-label">Avg Agg. Score</div>
263
+ <div class="stat-value" style="color:var(--primary)">0.83</div>
264
+ <div class="sparkline"><div class="sparkline-line"></div></div>
265
+ </div>
266
+ </div>
267
+
268
+ <div class="two-col">
269
+ <div>
270
+ <div class="table-wrap">
271
+ <table>
272
+ <thead>
273
+ <tr>
274
+ <th>Agent</th>
275
+ <th>Runs</th>
276
+ <th>Success</th>
277
+ <th>Avg Tokens</th>
278
+ <th>Agg Score</th>
279
+ <th>Last Run</th>
280
+ </tr>
281
+ </thead>
282
+ <tbody>
283
+ <tr onclick="showTab('runs')">
284
+ <td><div style="display:flex;align-items:center;gap:8px"><div class="agent-dot" style="background:var(--success)"></div><span style="font-weight:500">hermes</span></div></td>
285
+ <td class="td-mono">524</td>
286
+ <td><span style="color:var(--success);font-weight:500">94.2%</span></td>
287
+ <td class="td-mono">6,240</td>
288
+ <td><span class="score-badge score-high">0.89</span></td>
289
+ <td class="td-mono" style="color:var(--outline)">2m ago</td>
290
+ </tr>
291
+ <tr onclick="showTab('runs')">
292
+ <td><div style="display:flex;align-items:center;gap:8px"><div class="agent-dot" style="background:var(--success)"></div><span style="font-weight:500">claude-code</span></div></td>
293
+ <td class="td-mono">412</td>
294
+ <td><span style="color:var(--warning);font-weight:500">85.1%</span></td>
295
+ <td class="td-mono">8,100</td>
296
+ <td><span class="score-badge score-mid">0.81</span></td>
297
+ <td class="td-mono" style="color:var(--outline)">15m ago</td>
298
+ </tr>
299
+ <tr onclick="showTab('runs')">
300
+ <td><div style="display:flex;align-items:center;gap:8px"><div class="agent-dot" style="background:var(--outline)"></div><span style="font-weight:500">codex</span></div></td>
301
+ <td class="td-mono">311</td>
302
+ <td><span style="color:var(--error);font-weight:500">79.3%</span></td>
303
+ <td class="td-mono">9,800</td>
304
+ <td><span class="score-badge score-mid">0.76</span></td>
305
+ <td class="td-mono" style="color:var(--outline)">1h ago</td>
306
+ </tr>
307
+ </tbody>
308
+ </table>
309
+ </div>
310
+ </div>
311
+
312
+ <div class="score-dist">
313
+ <div class="section-title">Score Distribution</div>
314
+ <div style="margin-top:12px">
315
+ <div class="bar-row">
316
+ <div class="bar-label">hermes</div>
317
+ <div class="bar-track"><div class="bar-fill" style="width:89%"></div></div>
318
+ <div class="bar-value">0.89</div>
319
+ </div>
320
+ <div class="bar-row">
321
+ <div class="bar-label">claude-code</div>
322
+ <div class="bar-track"><div class="bar-fill" style="width:81%"></div></div>
323
+ <div class="bar-value">0.81</div>
324
+ </div>
325
+ <div class="bar-row">
326
+ <div class="bar-label">codex</div>
327
+ <div class="bar-track"><div class="bar-fill" style="width:76%"></div></div>
328
+ <div class="bar-value">0.76</div>
329
+ </div>
330
+ </div>
331
+ <div class="dist-section">By Scorer</div>
332
+ <div class="bar-row">
333
+ <div class="bar-label">outcome</div>
334
+ <div class="bar-track"><div class="bar-fill" style="width:91%"></div></div>
335
+ <div class="bar-value">0.91</div>
336
+ </div>
337
+ <div class="bar-row">
338
+ <div class="bar-label">tool_eff</div>
339
+ <div class="bar-track"><div class="bar-fill" style="width:68%"></div></div>
340
+ <div class="bar-value">0.68</div>
341
+ </div>
342
+ <div class="bar-row">
343
+ <div class="bar-label">token_cost</div>
344
+ <div class="bar-track"><div class="bar-fill" style="width:84%"></div></div>
345
+ <div class="bar-value">0.84</div>
346
+ </div>
347
+ <div class="bar-row">
348
+ <div class="bar-label">error_recov</div>
349
+ <div class="bar-track"><div class="bar-fill" style="width:80%"></div></div>
350
+ <div class="bar-value">0.80</div>
351
+ </div>
352
+ </div>
353
+ </div>
354
+ </div>
355
+
356
+ <!-- ── RUNS TAB ── -->
357
+ <div class="tab-content" id="tab-runs">
358
+ <div class="page-title">Runs</div>
359
+ <div class="filter-bar">
360
+ <button class="filter-btn active">Agent ▾</button>
361
+ <button class="filter-btn">Outcome ▾</button>
362
+ <button class="filter-btn">Since: 7d ▾</button>
363
+ <div class="filter-spacer"></div>
364
+ <button class="btn-secondary">↓ Export</button>
365
+ </div>
366
+ <div class="table-wrap">
367
+ <table>
368
+ <thead>
369
+ <tr>
370
+ <th style="width:32px"><input type="checkbox"></th>
371
+ <th>Run ID</th>
372
+ <th>Agent</th>
373
+ <th>Task</th>
374
+ <th>Outcome</th>
375
+ <th>Agg Score</th>
376
+ <th>Time</th>
377
+ </tr>
378
+ </thead>
379
+ <tbody>
380
+ <tr onclick="openDrawer('run-001','Refactor auth module','hermes','success',0.91,3,7000)">
381
+ <td><input type="checkbox" onclick="event.stopPropagation()"></td>
382
+ <td class="td-mono">run-001</td>
383
+ <td><span class="agent-chip">⬡ hermes</span></td>
384
+ <td>Refactor auth module</td>
385
+ <td><span class="pill pill-success">✓ success</span></td>
386
+ <td><span class="score-badge score-high">0.91</span></td>
387
+ <td class="td-mono" style="color:var(--outline)">2m</td>
388
+ </tr>
389
+ <tr onclick="openDrawer('run-002','Fix N+1 query in list','claude-code','success',0.84,2,9100)">
390
+ <td><input type="checkbox" onclick="event.stopPropagation()"></td>
391
+ <td class="td-mono">run-002</td>
392
+ <td><span class="agent-chip">≡ claude-code</span></td>
393
+ <td>Fix N+1 query in list</td>
394
+ <td><span class="pill pill-success">✓ success</span></td>
395
+ <td><span class="score-badge score-mid">0.84</span></td>
396
+ <td class="td-mono" style="color:var(--outline)">15m</td>
397
+ </tr>
398
+ <tr onclick="openDrawer('run-003','Add dark mode toggle','claude-code','failure',0.21,0,4200)">
399
+ <td><input type="checkbox" onclick="event.stopPropagation()"></td>
400
+ <td class="td-mono">run-003</td>
401
+ <td><span class="agent-chip">≡ claude-code</span></td>
402
+ <td>Add dark mode toggle</td>
403
+ <td><span class="pill pill-failure">✗ failure</span></td>
404
+ <td><span class="score-badge score-low">0.21</span></td>
405
+ <td class="td-mono" style="color:var(--outline)">23m</td>
406
+ </tr>
407
+ <tr onclick="openDrawer('run-004','Optimize skill prompt','hermes','partial',0.55,1,18000)">
408
+ <td><input type="checkbox" onclick="event.stopPropagation()"></td>
409
+ <td class="td-mono">run-004</td>
410
+ <td><span class="agent-chip">⬡ hermes</span></td>
411
+ <td>Optimize skill prompt</td>
412
+ <td><span class="pill pill-partial">~ partial</span></td>
413
+ <td><span class="score-badge score-mid">0.55</span></td>
414
+ <td class="td-mono" style="color:var(--outline)">45m</td>
415
+ </tr>
416
+ <tr onclick="openDrawer('run-005','Implement search feature','codex','success',0.77,5,12000)">
417
+ <td><input type="checkbox" onclick="event.stopPropagation()"></td>
418
+ <td class="td-mono">run-005</td>
419
+ <td><span class="agent-chip">⊕ codex</span></td>
420
+ <td>Implement search feature</td>
421
+ <td><span class="pill pill-success">✓ success</span></td>
422
+ <td><span class="score-badge score-mid">0.77</span></td>
423
+ <td class="td-mono" style="color:var(--outline)">1h</td>
424
+ </tr>
425
+ </tbody>
426
+ </table>
427
+ </div>
428
+ <div style="display:flex;justify-content:space-between;align-items:center;color:var(--outline);font-size:13px;">
429
+ <span>Showing 1–50 of 584 runs</span>
430
+ <div style="display:flex;gap:8px">
431
+ <button class="btn-secondary">← Prev</button>
432
+ <button class="btn-primary">1</button>
433
+ <button class="btn-secondary">2</button>
434
+ <button class="btn-secondary">3</button>
435
+ <button class="btn-secondary">Next →</button>
436
+ </div>
437
+ </div>
438
+ </div>
439
+
440
+ <!-- ── REGRESSION TAB ── -->
441
+ <div class="tab-content" id="tab-regression">
442
+ <div class="regression-page">
443
+ <div class="page-title">Regression Detection</div>
444
+ <div class="run-selector">
445
+ <div>
446
+ <div class="run-select-label">Baseline</div>
447
+ <div class="run-select-box">
448
+ <div>
449
+ <div class="run-select-id">run-001</div>
450
+ <div class="run-select-task">hermes · Refactor auth module</div>
451
+ </div>
452
+ <span style="color:var(--outline)">▾</span>
453
+ </div>
454
+ </div>
455
+ <div>
456
+ <div class="run-select-label">Evolved</div>
457
+ <div class="run-select-box">
458
+ <div>
459
+ <div class="run-select-id">run-002</div>
460
+ <div class="run-select-task">claude-code · Fix N+1 query</div>
461
+ </div>
462
+ <span style="color:var(--outline)">▾</span>
463
+ </div>
464
+ </div>
465
+ </div>
466
+
467
+ <div class="threshold-row">
468
+ <div class="threshold-label">Threshold</div>
469
+ <input type="range" min="1" max="20" value="5" id="threshold-slider" oninput="updateThreshold(this.value)">
470
+ <div class="threshold-val" id="threshold-val">0.05</div>
471
+ </div>
472
+
473
+ <div class="delta-banner improvement" id="delta-banner">
474
+ <div class="delta-banner-icon" style="color:var(--success)">▲</div>
475
+ <div>
476
+ <div class="delta-banner-title" style="color:var(--success)">IMPROVEMENT DETECTED &nbsp;<span class="mono">+0.07</span> &nbsp;<span style="font-weight:400;font-size:12px;color:var(--on-surface-variant)">(threshold: 0.05)</span></div>
477
+ <div class="delta-banner-sub">Evolved run significantly outperforms baseline</div>
478
+ </div>
479
+ </div>
480
+
481
+ <div class="table-wrap">
482
+ <table class="compare-table" style="width:100%">
483
+ <thead>
484
+ <tr>
485
+ <th>Scorer</th>
486
+ <th>Baseline</th>
487
+ <th>Evolved</th>
488
+ <th>Delta</th>
489
+ </tr>
490
+ </thead>
491
+ <tbody>
492
+ <tr>
493
+ <td style="font-weight:600;font-size:14px;">Aggregate</td>
494
+ <td class="td-mono">0.84</td>
495
+ <td class="td-mono">0.91</td>
496
+ <td class="delta-pos">+0.07 ▲</td>
497
+ </tr>
498
+ <tr class="improved">
499
+ <td>outcome</td>
500
+ <td class="td-mono">1.00 ✓</td>
501
+ <td class="td-mono">1.00 ✓</td>
502
+ <td class="delta-neu">+0.00 ●</td>
503
+ </tr>
504
+ <tr class="improved">
505
+ <td>tool_efficiency</td>
506
+ <td class="td-mono">0.45 ✗</td>
507
+ <td class="td-mono">0.67 ✓</td>
508
+ <td class="delta-pos">+0.22 ▲</td>
509
+ </tr>
510
+ <tr class="regressed">
511
+ <td>token_cost</td>
512
+ <td class="td-mono">0.91 ✓</td>
513
+ <td class="td-mono">0.86 ✓</td>
514
+ <td class="delta-neg">-0.05 ▼</td>
515
+ </tr>
516
+ <tr>
517
+ <td>error_recovery</td>
518
+ <td class="td-mono">1.00 ✓</td>
519
+ <td class="td-mono">1.00 ✓</td>
520
+ <td class="delta-neu">+0.00 ●</td>
521
+ </tr>
522
+ </tbody>
523
+ </table>
524
+ </div>
525
+ </div>
526
+ </div>
527
+
528
+ <!-- ── SCORERS TAB ── -->
529
+ <div class="tab-content" id="tab-scorers">
530
+ <div class="page-title">Scorers</div>
531
+ <div class="table-wrap">
532
+ <table>
533
+ <thead>
534
+ <tr>
535
+ <th>Scorer</th>
536
+ <th>Logic</th>
537
+ <th>Applies to</th>
538
+ <th>Pass condition</th>
539
+ </tr>
540
+ </thead>
541
+ <tbody>
542
+ <tr>
543
+ <td style="font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px">outcome</td>
544
+ <td style="font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--on-surface-variant)">success=1.0, partial=0.5, failure=0.0, unknown=0.3</td>
545
+ <td><span class="pill" style="background:var(--primary-5);color:var(--primary)">all runs</span></td>
546
+ <td class="td-mono">score > 0.5</td>
547
+ </tr>
548
+ <tr>
549
+ <td style="font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px">tool_efficiency</td>
550
+ <td style="font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--on-surface-variant)">unique_tools / total_calls</td>
551
+ <td><span class="pill" style="background:var(--neutral-bg);color:var(--outline)">w/ tool_calls</span></td>
552
+ <td class="td-mono">ratio > 0.3</td>
553
+ </tr>
554
+ <tr>
555
+ <td style="font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px">token_cost</td>
556
+ <td style="font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--on-surface-variant)">max(0, 1 - tokens/50000)</td>
557
+ <td><span class="pill" style="background:var(--neutral-bg);color:var(--outline)">w/ metrics</span></td>
558
+ <td class="td-mono">tokens &lt; 50,000</td>
559
+ </tr>
560
+ <tr>
561
+ <td style="font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px">error_recovery</td>
562
+ <td style="font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--on-surface-variant)">success_no_err=1.0, w_err=0.8, failure=0.0</td>
563
+ <td><span class="pill" style="background:var(--primary-5);color:var(--primary)">all runs</span></td>
564
+ <td class="td-mono">outcome = success</td>
565
+ </tr>
566
+ <tr>
567
+ <td style="font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px">delta</td>
568
+ <td style="font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--on-surface-variant)">wraps DeltaValidator (DSPy+GEPA holdout)</td>
569
+ <td><span class="pill" style="background:rgba(169,56,0,0.08);color:var(--accent)">hermes only</span></td>
570
+ <td class="td-mono">|Δ| ≥ threshold</td>
571
+ </tr>
572
+ </tbody>
573
+ </table>
574
+ </div>
575
+ </div>
576
+
577
+ </div>
578
+ </div>
579
+
580
+ <!-- Run Detail Drawer -->
581
+ <div class="drawer-overlay" id="drawer-overlay" onclick="closeDrawer(event)">
582
+ <div class="drawer" id="drawer">
583
+ <button class="drawer-close" onclick="closeDrawerDirect()">✕</button>
584
+ <div class="drawer-head">
585
+ <div class="drawer-run-id" id="d-run-id">run-001</div>
586
+ <div class="drawer-task" id="d-task">Refactor auth module</div>
587
+ <div class="drawer-meta">
588
+ <span class="agent-chip" id="d-agent">⬡ hermes</span>
589
+ <span id="d-outcome"><span class="pill pill-success">✓ success</span></span>
590
+ <span style="color:var(--outline)">2m ago</span>
591
+ </div>
592
+ </div>
593
+ <div class="drawer-body">
594
+ <div>
595
+ <div class="drawer-section-title">Aggregate Score</div>
596
+ <div class="agg-score-block">
597
+ <div class="stat-label">AGGREGATE SCORE</div>
598
+ <div class="agg-score-num" id="d-agg-score">0.91</div>
599
+ <div class="score-bar"><div class="score-bar-fill" id="d-score-bar" style="width:91%"></div></div>
600
+ </div>
601
+ </div>
602
+ <div>
603
+ <div class="drawer-section-title">Scorer Breakdown</div>
604
+ <table class="breakdown-table">
605
+ <thead><tr><th>Scorer</th><th>Score</th><th>Passed</th><th>Details</th></tr></thead>
606
+ <tbody id="d-breakdown">
607
+ </tbody>
608
+ </table>
609
+ </div>
610
+ <div>
611
+ <div class="drawer-section-title">Metrics</div>
612
+ <div id="d-metrics"></div>
613
+ </div>
614
+ </div>
615
+ <div class="drawer-footer">
616
+ <button class="btn-primary" onclick="closeDrawerDirect();showTab('regression')">Compare with...</button>
617
+ <button class="btn-secondary">Re-evaluate</button>
618
+ </div>
619
+ </div>
620
+ </div>
621
+
622
+ <script>
623
+ function showTab(name) {
624
+ document.querySelectorAll('.tab').forEach((t,i) => {
625
+ const tabs = ['agents','runs','regression','scorers'];
626
+ t.classList.toggle('active', tabs[i] === name);
627
+ });
628
+ document.querySelectorAll('.tab-content').forEach(c => c.classList.remove('active'));
629
+ document.getElementById('tab-'+name).classList.add('active');
630
+ }
631
+
632
+ function openDrawer(runId, task, agent, outcome, aggScore, toolCalls, tokens) {
633
+ document.getElementById('d-run-id').textContent = runId;
634
+ document.getElementById('d-task').textContent = task;
635
+ document.getElementById('d-agent').textContent = (agent === 'hermes' ? '⬡ ' : '≡ ') + agent;
636
+ document.getElementById('d-agg-score').textContent = aggScore.toFixed(2);
637
+ document.getElementById('d-score-bar').style.width = (aggScore*100) + '%';
638
+ const outcomeEl = document.getElementById('d-outcome');
639
+ if (outcome === 'success') outcomeEl.innerHTML = '<span class="pill pill-success">✓ success</span>';
640
+ else if (outcome === 'failure') outcomeEl.innerHTML = '<span class="pill pill-failure">✗ failure</span>';
641
+ else outcomeEl.innerHTML = '<span class="pill pill-partial">~ partial</span>';
642
+
643
+ const tokenScore = Math.max(0, 1 - tokens/50000);
644
+ const toolScore = toolCalls > 0 ? 0.67 : 1.0;
645
+ const outcomeScore = outcome === 'success' ? 1.0 : outcome === 'partial' ? 0.5 : 0.0;
646
+ const errorScore = outcome === 'success' ? 1.0 : 0.0;
647
+
648
+ const rows = [
649
+ ['outcome', outcomeScore.toFixed(2), outcomeScore > 0.5, `outcome: ${outcome}`],
650
+ ['tool_efficiency', toolScore.toFixed(2), toolScore > 0.3, toolCalls > 0 ? `${toolCalls} calls` : 'no tools'],
651
+ ['token_cost', tokenScore.toFixed(2), tokens < 50000, `${tokens.toLocaleString()} tokens`],
652
+ ['error_recovery', errorScore.toFixed(2), outcome === 'success', `outcome: ${outcome}`],
653
+ ];
654
+
655
+ document.getElementById('d-breakdown').innerHTML = rows.map(([s,sc,p,d]) =>
656
+ `<tr><td class="mono" style="font-size:12px">${s}</td><td class="mono">${sc}</td><td>${p?'<span style="color:var(--success)">✓</span>':'<span style="color:var(--error)">✗</span>'}</td><td class="td-mono">${d}</td></tr>`
657
+ ).join('') + `<tr class="total"><td>aggregate</td><td class="mono">${aggScore.toFixed(2)}</td><td></td><td></td></tr>`;
658
+
659
+ document.getElementById('d-metrics').innerHTML = `
660
+ <div class="metric-row"><span class="metric-key">total_tokens</span><span class="metric-val">${tokens.toLocaleString()}</span></div>
661
+ <div class="metric-row"><span class="metric-key">tool_calls</span><span class="metric-val">${toolCalls}</span></div>
662
+ <div class="metric-row"><span class="metric-key">outcome</span><span class="metric-val">${outcome}</span></div>
663
+ `;
664
+
665
+ document.getElementById('drawer-overlay').classList.add('open');
666
+ }
667
+
668
+ function closeDrawer(e) { if (e.target === document.getElementById('drawer-overlay')) closeDrawerDirect(); }
669
+ function closeDrawerDirect() { document.getElementById('drawer-overlay').classList.remove('open'); }
670
+
671
+ function updateThreshold(val) {
672
+ document.getElementById('threshold-val').textContent = '0.0' + (val < 10 ? val : val);
673
+ }
674
+ </script>
675
+ </body>
676
+ </html>