project-graph-mcp 2.3.2 → 2.4.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 (279) hide show
  1. package/package.json +3 -2
  2. package/src/analysis/analysis-cache.ctx +9 -0
  3. package/src/analysis/analysis-cache.js +1 -1
  4. package/src/analysis/complexity.ctx +6 -0
  5. package/src/analysis/complexity.js +1 -1
  6. package/src/analysis/custom-rules.ctx +14 -0
  7. package/src/analysis/custom-rules.js +1 -1
  8. package/src/analysis/db-analysis.ctx +7 -0
  9. package/src/analysis/db-analysis.js +1 -1
  10. package/src/analysis/dead-code.ctx +6 -0
  11. package/src/analysis/dead-code.js +1 -1
  12. package/src/analysis/full-analysis.ctx +9 -0
  13. package/src/analysis/full-analysis.js +1 -1
  14. package/src/analysis/jsdoc-checker.ctx +10 -0
  15. package/src/analysis/jsdoc-checker.js +1 -1
  16. package/src/analysis/jsdoc-generator.ctx +9 -0
  17. package/src/analysis/jsdoc-generator.js +1 -1
  18. package/src/analysis/large-files.ctx +6 -0
  19. package/src/analysis/large-files.js +1 -1
  20. package/src/analysis/outdated-patterns.ctx +7 -0
  21. package/src/analysis/outdated-patterns.js +1 -1
  22. package/src/analysis/similar-functions.ctx +6 -0
  23. package/src/analysis/similar-functions.js +1 -1
  24. package/src/analysis/test-annotations.ctx +11 -0
  25. package/src/analysis/test-annotations.js +1 -1
  26. package/src/analysis/type-checker.ctx +6 -0
  27. package/src/analysis/type-checker.js +1 -1
  28. package/src/analysis/undocumented.ctx +8 -0
  29. package/src/analysis/undocumented.js +1 -1
  30. package/src/cli/cli-handlers.ctx +7 -0
  31. package/src/cli/cli-handlers.js +1 -1
  32. package/src/cli/cli.ctx +6 -0
  33. package/src/cli/cli.js +1 -1
  34. package/src/compact/ai-context.ctx +6 -0
  35. package/src/compact/ai-context.js +1 -1
  36. package/src/compact/compact-migrate.ctx +8 -0
  37. package/src/compact/compact-migrate.js +1 -1
  38. package/src/compact/compact.ctx +11 -0
  39. package/src/compact/compact.js +1 -1
  40. package/src/compact/compress.ctx +7 -0
  41. package/src/compact/compress.js +1 -1
  42. package/src/compact/ctx-resolver.ctx +2 -0
  43. package/src/compact/ctx-resolver.js +1 -1
  44. package/src/compact/ctx-to-jsdoc.ctx +11 -0
  45. package/src/compact/ctx-to-jsdoc.js +1 -1
  46. package/src/compact/doc-dialect.ctx +11 -0
  47. package/src/compact/doc-dialect.js +2 -2
  48. package/src/compact/expand.ctx +14 -0
  49. package/src/compact/expand.js +1 -1
  50. package/src/compact/framework-references.ctx +7 -0
  51. package/src/compact/framework-references.js +1 -1
  52. package/src/compact/instructions.ctx +6 -0
  53. package/src/compact/instructions.js +1 -1
  54. package/src/compact/jsdoc-builder.ctx +4 -0
  55. package/src/compact/jsdoc-builder.js +1 -1
  56. package/src/compact/mode-config.ctx +8 -0
  57. package/src/compact/mode-config.js +1 -1
  58. package/src/compact/split-declarations.ctx +6 -0
  59. package/src/compact/split-declarations.js +1 -1
  60. package/src/compact/validate-pipeline.ctx +12 -0
  61. package/src/compact/validate-pipeline.js +1 -1
  62. package/src/core/event-bus.ctx +9 -0
  63. package/src/core/event-bus.js +1 -1
  64. package/src/core/file-walker.ctx +1 -0
  65. package/src/core/file-walker.js +1 -1
  66. package/src/core/filters.ctx +12 -0
  67. package/src/core/filters.js +1 -1
  68. package/src/core/graph-builder.ctx +7 -0
  69. package/src/core/graph-builder.js +1 -1
  70. package/src/core/parser.ctx +12 -0
  71. package/src/core/parser.js +1 -1
  72. package/src/core/utils.ctx +1 -0
  73. package/src/core/utils.js +1 -1
  74. package/src/core/workspace.ctx +7 -0
  75. package/src/core/workspace.js +1 -1
  76. package/src/lang/lang-go.ctx +8 -0
  77. package/src/lang/lang-go.js +1 -1
  78. package/src/lang/lang-python.ctx +5 -0
  79. package/src/lang/lang-python.js +1 -1
  80. package/src/lang/lang-sql.ctx +10 -0
  81. package/src/lang/lang-sql.js +1 -1
  82. package/src/lang/lang-typescript.ctx +6 -0
  83. package/src/lang/lang-typescript.js +1 -1
  84. package/src/lang/lang-utils.ctx +5 -0
  85. package/src/lang/lang-utils.js +1 -1
  86. package/src/mcp/mcp-server.ctx +6 -0
  87. package/src/mcp/mcp-server.js +1 -1
  88. package/src/mcp/tool-defs.ctx +2 -0
  89. package/src/mcp/tool-defs.js +1 -1
  90. package/src/mcp/tools.ctx +13 -0
  91. package/src/mcp/tools.js +1 -1
  92. package/src/network/backend-lifecycle.ctx +10 -0
  93. package/src/network/backend-lifecycle.js +1 -1
  94. package/src/network/backend.ctx +5 -0
  95. package/src/network/backend.js +1 -1
  96. package/src/network/local-gateway.ctx +9 -0
  97. package/src/network/local-gateway.js +1 -1
  98. package/src/network/mdns.ctx +6 -0
  99. package/src/network/mdns.js +1 -1
  100. package/src/network/server.ctx +2 -0
  101. package/src/network/server.js +2 -2
  102. package/src/network/web-server.ctx +17 -0
  103. package/src/network/web-server.js +2 -2
  104. package/web/follow-controller.js +94 -25
  105. package/web/panels/dep-graph.js +207 -21
  106. package/project-graph-mcp-2.3.0.tgz +0 -0
  107. package/vendor/symbiote-node/CHANGELOG.md +0 -31
  108. package/vendor/symbiote-node/LICENSE +0 -21
  109. package/vendor/symbiote-node/README.md +0 -206
  110. package/vendor/symbiote-node/canvas/AutoLayout.js +0 -725
  111. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.css.js +0 -73
  112. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.js +0 -93
  113. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.tpl.js +0 -9
  114. package/vendor/symbiote-node/canvas/CanvasConnectionRenderer.js +0 -962
  115. package/vendor/symbiote-node/canvas/ConnectionRenderer.js +0 -1468
  116. package/vendor/symbiote-node/canvas/FlowSimulator.js +0 -323
  117. package/vendor/symbiote-node/canvas/ForceLayout.js +0 -189
  118. package/vendor/symbiote-node/canvas/ForceWorker.js +0 -1325
  119. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.css.js +0 -97
  120. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.js +0 -176
  121. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.tpl.js +0 -12
  122. package/vendor/symbiote-node/canvas/LODManager.js +0 -88
  123. package/vendor/symbiote-node/canvas/Minimap/Minimap.css.js +0 -71
  124. package/vendor/symbiote-node/canvas/Minimap/Minimap.js +0 -207
  125. package/vendor/symbiote-node/canvas/Minimap/Minimap.tpl.js +0 -9
  126. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.css.js +0 -261
  127. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.js +0 -1840
  128. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.tpl.js +0 -22
  129. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.css.js +0 -97
  130. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.js +0 -132
  131. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.tpl.js +0 -21
  132. package/vendor/symbiote-node/canvas/NodeViewManager.js +0 -584
  133. package/vendor/symbiote-node/canvas/PinExpansion.js +0 -131
  134. package/vendor/symbiote-node/canvas/PseudoConnection.js +0 -80
  135. package/vendor/symbiote-node/canvas/SubgraphManager.js +0 -201
  136. package/vendor/symbiote-node/canvas/SubgraphRouter.js +0 -443
  137. package/vendor/symbiote-node/canvas/ViewportActions.js +0 -446
  138. package/vendor/symbiote-node/core/Connection.js +0 -45
  139. package/vendor/symbiote-node/core/Editor.js +0 -451
  140. package/vendor/symbiote-node/core/Frame.js +0 -31
  141. package/vendor/symbiote-node/core/GraphMermaid.js +0 -348
  142. package/vendor/symbiote-node/core/GraphText.js +0 -210
  143. package/vendor/symbiote-node/core/Node.js +0 -143
  144. package/vendor/symbiote-node/core/Portal.js +0 -104
  145. package/vendor/symbiote-node/core/Socket.js +0 -185
  146. package/vendor/symbiote-node/core/SubgraphNode.js +0 -125
  147. package/vendor/symbiote-node/engine/AgentUICommands.js +0 -100
  148. package/vendor/symbiote-node/engine/Executor.js +0 -371
  149. package/vendor/symbiote-node/engine/Graph.js +0 -314
  150. package/vendor/symbiote-node/engine/GraphServer.js +0 -353
  151. package/vendor/symbiote-node/engine/HandlerLoader.js +0 -145
  152. package/vendor/symbiote-node/engine/History.js +0 -83
  153. package/vendor/symbiote-node/engine/Lifecycle.js +0 -118
  154. package/vendor/symbiote-node/engine/Persistence.js +0 -84
  155. package/vendor/symbiote-node/engine/Registry.js +0 -264
  156. package/vendor/symbiote-node/engine/SocketTypes.js +0 -79
  157. package/vendor/symbiote-node/engine/cli.js +0 -404
  158. package/vendor/symbiote-node/engine/index.js +0 -56
  159. package/vendor/symbiote-node/engine/nanoid.js +0 -28
  160. package/vendor/symbiote-node/engine/package.json +0 -26
  161. package/vendor/symbiote-node/engine/packs/ai/beat-detect.handler.js +0 -215
  162. package/vendor/symbiote-node/engine/packs/ai/content-adapt.handler.js +0 -238
  163. package/vendor/symbiote-node/engine/packs/ai/face-detect.handler.js +0 -287
  164. package/vendor/symbiote-node/engine/packs/ai/grok-generate.handler.js +0 -565
  165. package/vendor/symbiote-node/engine/packs/ai/kling-lipsync.handler.js +0 -414
  166. package/vendor/symbiote-node/engine/packs/ai/lesson-generate.handler.js +0 -343
  167. package/vendor/symbiote-node/engine/packs/ai/opencode.handler.js +0 -164
  168. package/vendor/symbiote-node/engine/packs/ai/replicate-lipsync.handler.js +0 -341
  169. package/vendor/symbiote-node/engine/packs/ai/tts.handler.js +0 -241
  170. package/vendor/symbiote-node/engine/packs/ai/whisper.handler.js +0 -191
  171. package/vendor/symbiote-node/engine/packs/data/db-query.handler.js +0 -67
  172. package/vendor/symbiote-node/engine/packs/data/news-accumulate.handler.js +0 -281
  173. package/vendor/symbiote-node/engine/packs/data/personas.handler.js +0 -160
  174. package/vendor/symbiote-node/engine/packs/data/prompt-loader.handler.js +0 -193
  175. package/vendor/symbiote-node/engine/packs/data/roles.handler.js +0 -216
  176. package/vendor/symbiote-node/engine/packs/data/rss-feed.handler.js +0 -244
  177. package/vendor/symbiote-node/engine/packs/debug/inject.handler.js +0 -52
  178. package/vendor/symbiote-node/engine/packs/flow/agent.handler.js +0 -73
  179. package/vendor/symbiote-node/engine/packs/flow/if.handler.js +0 -107
  180. package/vendor/symbiote-node/engine/packs/flow/loop.handler.js +0 -58
  181. package/vendor/symbiote-node/engine/packs/flow/merge.handler.js +0 -60
  182. package/vendor/symbiote-node/engine/packs/flow/retry.handler.js +0 -65
  183. package/vendor/symbiote-node/engine/packs/flow/switch.handler.js +0 -64
  184. package/vendor/symbiote-node/engine/packs/flow/wait-all.handler.js +0 -39
  185. package/vendor/symbiote-node/engine/packs/io/http-request.handler.js +0 -82
  186. package/vendor/symbiote-node/engine/packs/io/read-file.handler.js +0 -60
  187. package/vendor/symbiote-node/engine/packs/io/write-file.handler.js +0 -63
  188. package/vendor/symbiote-node/engine/packs/transform/anchor-match.handler.js +0 -494
  189. package/vendor/symbiote-node/engine/packs/transform/effects-skeleton.handler.js +0 -417
  190. package/vendor/symbiote-node/engine/packs/transform/json-parse.handler.js +0 -43
  191. package/vendor/symbiote-node/engine/packs/transform/lipsync-select.handler.js +0 -339
  192. package/vendor/symbiote-node/engine/packs/transform/riopla-adapt.handler.js +0 -432
  193. package/vendor/symbiote-node/engine/packs/transform/set.handler.js +0 -57
  194. package/vendor/symbiote-node/engine/packs/transform/template-builder.handler.js +0 -134
  195. package/vendor/symbiote-node/engine/packs/transform/template.handler.js +0 -79
  196. package/vendor/symbiote-node/engine/packs/transform/timeline-build.handler.js +0 -399
  197. package/vendor/symbiote-node/engine/packs/util/delay.handler.js +0 -39
  198. package/vendor/symbiote-node/engine/packs/util/log.handler.js +0 -44
  199. package/vendor/symbiote-node/engine/packs/video-pack.js +0 -323
  200. package/vendor/symbiote-node/index.js +0 -103
  201. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.css.js +0 -361
  202. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.js +0 -332
  203. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.tpl.js +0 -96
  204. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.css.js +0 -104
  205. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.js +0 -133
  206. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.tpl.js +0 -33
  207. package/vendor/symbiote-node/interactions/ConnectFlow.js +0 -307
  208. package/vendor/symbiote-node/interactions/Drag.js +0 -102
  209. package/vendor/symbiote-node/interactions/Selector.js +0 -132
  210. package/vendor/symbiote-node/interactions/SnapGrid.js +0 -65
  211. package/vendor/symbiote-node/interactions/Zoom.js +0 -140
  212. package/vendor/symbiote-node/layout/ActionZone/ActionZone.css.js +0 -88
  213. package/vendor/symbiote-node/layout/ActionZone/ActionZone.js +0 -254
  214. package/vendor/symbiote-node/layout/ActionZone/ActionZone.tpl.js +0 -11
  215. package/vendor/symbiote-node/layout/Layout/Layout.css.js +0 -88
  216. package/vendor/symbiote-node/layout/Layout/Layout.js +0 -622
  217. package/vendor/symbiote-node/layout/Layout/Layout.tpl.js +0 -25
  218. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.css.js +0 -293
  219. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.js +0 -467
  220. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.tpl.js +0 -33
  221. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.css.js +0 -46
  222. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.js +0 -102
  223. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.tpl.js +0 -6
  224. package/vendor/symbiote-node/layout/LayoutRouter/LayoutRouter.js +0 -156
  225. package/vendor/symbiote-node/layout/LayoutRouter/routerSync.js +0 -250
  226. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.css.js +0 -379
  227. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.js +0 -263
  228. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.tpl.js +0 -20
  229. package/vendor/symbiote-node/layout/LayoutSidebar/SidebarSection.js +0 -183
  230. package/vendor/symbiote-node/layout/LayoutTree.js +0 -246
  231. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.css.js +0 -43
  232. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.js +0 -89
  233. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.tpl.js +0 -14
  234. package/vendor/symbiote-node/layout/index.js +0 -16
  235. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.css.js +0 -61
  236. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.js +0 -79
  237. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.tpl.js +0 -19
  238. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.css.js +0 -41
  239. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.js +0 -24
  240. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.tpl.js +0 -16
  241. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.css.js +0 -65
  242. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.js +0 -29
  243. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.tpl.js +0 -13
  244. package/vendor/symbiote-node/node/GraphNode/GraphNode.css.js +0 -683
  245. package/vendor/symbiote-node/node/GraphNode/GraphNode.js +0 -92
  246. package/vendor/symbiote-node/node/GraphNode/GraphNode.tpl.js +0 -17
  247. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.js +0 -25
  248. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.tpl.js +0 -7
  249. package/vendor/symbiote-node/node/PortItem/PortItem.css.js +0 -90
  250. package/vendor/symbiote-node/node/PortItem/PortItem.js +0 -87
  251. package/vendor/symbiote-node/node/PortItem/PortItem.tpl.js +0 -10
  252. package/vendor/symbiote-node/package.json +0 -59
  253. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.css.js +0 -143
  254. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.js +0 -131
  255. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.tpl.js +0 -16
  256. package/vendor/symbiote-node/plugins/History.js +0 -384
  257. package/vendor/symbiote-node/plugins/Readonly.js +0 -59
  258. package/vendor/symbiote-node/shapes/CircleShape.js +0 -80
  259. package/vendor/symbiote-node/shapes/CommentShape.js +0 -35
  260. package/vendor/symbiote-node/shapes/DiamondShape.js +0 -115
  261. package/vendor/symbiote-node/shapes/NodeShape.js +0 -80
  262. package/vendor/symbiote-node/shapes/PillShape.js +0 -91
  263. package/vendor/symbiote-node/shapes/RectShape.js +0 -72
  264. package/vendor/symbiote-node/shapes/SVGShape.js +0 -494
  265. package/vendor/symbiote-node/shapes/index.js +0 -53
  266. package/vendor/symbiote-node/themes/Palette.js +0 -32
  267. package/vendor/symbiote-node/themes/Skin.js +0 -113
  268. package/vendor/symbiote-node/themes/Theme.js +0 -84
  269. package/vendor/symbiote-node/themes/carbon.js +0 -137
  270. package/vendor/symbiote-node/themes/dark.js +0 -137
  271. package/vendor/symbiote-node/themes/ebook.js +0 -138
  272. package/vendor/symbiote-node/themes/grey.js +0 -137
  273. package/vendor/symbiote-node/themes/light.js +0 -137
  274. package/vendor/symbiote-node/themes/neon.js +0 -138
  275. package/vendor/symbiote-node/themes/pcb.js +0 -273
  276. package/vendor/symbiote-node/themes/synthwave.js +0 -137
  277. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.css.js +0 -86
  278. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.js +0 -128
  279. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.tpl.js +0 -29
@@ -1,137 +0,0 @@
1
- /**
2
- * Light Clean — bright minimal theme
3
- *
4
- * Inverted lightness values: bg=95%, surface=100%, text=15%.
5
- * Same atomic HSL structure as dark theme.
6
- *
7
- * @module symbiote-node/themes/light
8
- */
9
-
10
- /** @type {import('./Theme.js').ThemeDefinition} */
11
- export const LIGHT_CLEAN = {
12
- name: 'light-clean',
13
- tokens: {
14
- // === Atomic tokens ===
15
-
16
- // Hues
17
- '--sn-hue-base': '220',
18
- '--sn-hue-accent': '217',
19
- '--sn-hue-success': '142',
20
- '--sn-hue-warning': '38',
21
- '--sn-hue-danger': '0',
22
- '--sn-hue-data': '262',
23
-
24
- // Saturation levels
25
- '--sn-sat': '14%',
26
- '--sn-sat-vivid': '60%',
27
- '--sn-sat-muted': '8%',
28
-
29
- // Lightness levels (inverted for light theme)
30
- '--sn-lit-bg': '95%',
31
- '--sn-lit-surface': '100%',
32
- '--sn-lit-border': '78%',
33
- '--sn-lit-hover': '90%',
34
- '--sn-lit-text': '15%',
35
- '--sn-lit-text-dim': '45%',
36
- '--sn-lit-accent': '50%',
37
-
38
- // Alpha levels
39
- '--sn-alpha-overlay': '0.95',
40
- '--sn-alpha-subtle': '0.1',
41
- '--sn-alpha-faint': '0.12',
42
-
43
- // Semantic state colors (composed from atomics)
44
- '--sn-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent))',
45
- '--sn-success-color': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), var(--sn-lit-accent))',
46
- '--sn-warning-color': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), var(--sn-lit-accent))',
47
-
48
- // === Composed tokens ===
49
-
50
- // Canvas
51
- '--sn-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-bg))',
52
- '--sn-grid-dot': 'hsla(0, 0%, 0%, var(--sn-alpha-faint))',
53
- '--sn-grid-size': '20px',
54
-
55
- // Node
56
- '--sn-node-bg': 'hsl(0, 0%, var(--sn-lit-surface))',
57
- '--sn-node-border': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-border))',
58
- '--sn-node-radius': '10px',
59
- '--sn-node-shadow': '0 2px 8px rgba(0, 0, 0, 0.08)',
60
- '--sn-shadow-color': 'rgba(0, 0, 0, 0.12)',
61
- '--sn-node-selected': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent))',
62
- '--sn-node-hover': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-hover))',
63
- '--sn-node-header-bg': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), 96%)',
64
-
65
- // Typography
66
- '--sn-font': "'Inter', sans-serif",
67
- '--sn-text': 'hsl(var(--sn-hue-base), 10%, var(--sn-lit-text))',
68
- '--sn-text-dim': 'hsl(var(--sn-hue-base), 8%, var(--sn-lit-text-dim))',
69
-
70
- // Sockets
71
- '--sn-socket-size': '12px',
72
- '--sn-socket-border-width': '2px',
73
-
74
- // Connections
75
- '--sn-conn-color': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent))',
76
- '--sn-conn-width': '2',
77
- '--sn-conn-selected': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent))',
78
-
79
- // Category accent colors
80
- '--sn-cat-server': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent))',
81
- '--sn-cat-instance': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 45%)',
82
- '--sn-cat-control': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), var(--sn-lit-accent))',
83
- '--sn-cat-data': 'hsl(var(--sn-hue-data), var(--sn-sat-vivid), 55%)',
84
- '--sn-cat-default': 'hsl(0, 0%, var(--sn-lit-text-dim))',
85
-
86
- // Context menu
87
- '--sn-ctx-bg': 'hsl(0, 0%, var(--sn-lit-surface))',
88
- '--sn-ctx-border': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-hover))',
89
- '--sn-ctx-color': 'hsl(var(--sn-hue-base), 10%, var(--sn-lit-text))',
90
- '--sn-ctx-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent), var(--sn-alpha-subtle))',
91
-
92
- // Comments
93
- '--sn-comment-bg': 'hsla(0, 0%, 0%, 0.03)',
94
- '--sn-comment-border': 'hsla(0, 0%, 0%, 0.08)',
95
- '--sn-comment-radius': '6px',
96
-
97
- // Toolbar
98
- '--sn-toolbar-bg': 'hsla(0, 0%, var(--sn-lit-surface), var(--sn-alpha-overlay))',
99
- '--sn-toolbar-border': 'hsla(0, 0%, 0%, 0.1)',
100
- '--sn-toolbar-color': 'hsl(var(--sn-hue-base), 8%, 35%)',
101
- '--sn-toolbar-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent), 0.12)',
102
- '--sn-toolbar-active': 'hsl(var(--sn-hue-base), 10%, var(--sn-lit-text))',
103
- '--sn-toolbar-danger': 'hsla(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent), 0.15)',
104
- '--sn-toolbar-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent))',
105
-
106
- // Shape fill/stroke
107
- '--sn-shape-fill': 'var(--sn-node-bg)',
108
- '--sn-shape-stroke': 'var(--sn-node-border)',
109
- '--sn-shape-stroke-width': '1.0',
110
- },
111
- };
112
-
113
- /** @type {import('./Palette.js').PaletteDefinition} */
114
- export const LIGHT_PALETTE = {
115
- name: 'light',
116
- colors: {
117
- '--sn-hue-base': '220',
118
- '--sn-hue-accent': '217',
119
- '--sn-hue-success': '142',
120
- '--sn-hue-warning': '38',
121
- '--sn-hue-danger': '0',
122
- '--sn-hue-data': '262',
123
- '--sn-sat': '14%',
124
- '--sn-sat-vivid': '60%',
125
- '--sn-sat-muted': '8%',
126
- '--sn-lit-bg': '95%',
127
- '--sn-lit-surface': '100%',
128
- '--sn-lit-border': '78%',
129
- '--sn-lit-hover': '90%',
130
- '--sn-lit-text': '15%',
131
- '--sn-lit-text-dim': '45%',
132
- '--sn-lit-accent': '50%',
133
- '--sn-alpha-overlay': '0.95',
134
- '--sn-alpha-subtle': '0.1',
135
- '--sn-alpha-faint': '0.12',
136
- },
137
- };
@@ -1,138 +0,0 @@
1
- /**
2
- * Neon Glow — electric neon theme with luminous edges
3
- *
4
- * Deep black base (hue 230) with electric cyan accent (185).
5
- * All borders and shapes emit visible glow via elevated alpha
6
- * and vivid saturation. Designed for maximum visual impact.
7
- *
8
- * @module symbiote-node/themes/neon
9
- */
10
-
11
- /** @type {import('./Theme.js').ThemeDefinition} */
12
- export const NEON_GLOW = {
13
- name: 'neon-glow',
14
- tokens: {
15
- // === Atomic tokens ===
16
-
17
- // Hues
18
- '--sn-hue-base': '230',
19
- '--sn-hue-accent': '185',
20
- '--sn-hue-success': '150',
21
- '--sn-hue-warning': '50',
22
- '--sn-hue-danger': '355',
23
- '--sn-hue-data': '280',
24
-
25
- // Saturation levels (high neon saturation)
26
- '--sn-sat': '30%',
27
- '--sn-sat-vivid': '100%',
28
- '--sn-sat-muted': '15%',
29
-
30
- // Lightness levels (very dark base)
31
- '--sn-lit-bg': '4%',
32
- '--sn-lit-surface': '8%',
33
- '--sn-lit-border': '22%',
34
- '--sn-lit-hover': '14%',
35
- '--sn-lit-text': '90%',
36
- '--sn-lit-text-dim': '55%',
37
- '--sn-lit-accent': '60%',
38
-
39
- // Alpha levels
40
- '--sn-alpha-overlay': '0.94',
41
- '--sn-alpha-subtle': '0.2',
42
- '--sn-alpha-faint': '0.06',
43
-
44
- // Semantic state colors
45
- '--sn-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent))',
46
- '--sn-success-color': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), var(--sn-lit-accent))',
47
- '--sn-warning-color': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), var(--sn-lit-accent))',
48
-
49
- // === Composed tokens ===
50
-
51
- // Canvas — near-black with cyan grid glow
52
- '--sn-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-bg))',
53
- '--sn-grid-dot': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.12)',
54
- '--sn-grid-size': '22px',
55
-
56
- // Node — dark glass with neon edge glow
57
- '--sn-node-bg': 'hsla(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-surface), 0.9)',
58
- '--sn-node-border': 'hsl(var(--sn-hue-accent), 60%, 30%)',
59
- '--sn-node-radius': '8px',
60
- '--sn-node-shadow': '0 0 12px hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.15), 0 4px 16px rgba(0, 0, 0, 0.5)',
61
- '--sn-shadow-color': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.15)',
62
- '--sn-node-selected': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 55%)',
63
- '--sn-node-hover': 'hsl(var(--sn-hue-base), 25%, var(--sn-lit-hover))',
64
- '--sn-node-header-bg': 'hsla(var(--sn-hue-accent), 40%, 10%, 0.6)',
65
-
66
- // Typography
67
- '--sn-font': "'JetBrains Mono', 'Fira Code', monospace",
68
- '--sn-text': 'hsl(var(--sn-hue-accent), 20%, var(--sn-lit-text))',
69
- '--sn-text-dim': 'hsl(var(--sn-hue-accent), 15%, var(--sn-lit-text-dim))',
70
-
71
- // Sockets
72
- '--sn-socket-size': '12px',
73
- '--sn-socket-border-width': '2px',
74
-
75
- // Connections — bright neon wires
76
- '--sn-conn-color': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 55%)',
77
- '--sn-conn-width': '2',
78
- '--sn-conn-selected': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), 60%)',
79
-
80
- // Category accent colors (electric neon palette)
81
- '--sn-cat-server': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 55%)',
82
- '--sn-cat-instance': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 55%)',
83
- '--sn-cat-control': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), 55%)',
84
- '--sn-cat-data': 'hsl(var(--sn-hue-data), var(--sn-sat-vivid), 65%)',
85
- '--sn-cat-default': 'hsl(var(--sn-hue-accent), 30%, 45%)',
86
-
87
- // Context menu
88
- '--sn-ctx-bg': 'hsla(var(--sn-hue-base), var(--sn-sat), 6%, 0.96)',
89
- '--sn-ctx-border': 'hsl(var(--sn-hue-accent), 50%, 25%)',
90
- '--sn-ctx-color': 'hsl(var(--sn-hue-accent), 20%, var(--sn-lit-text))',
91
- '--sn-ctx-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.15)',
92
-
93
- // Comments
94
- '--sn-comment-bg': 'hsla(var(--sn-hue-accent), 80%, 50%, 0.04)',
95
- '--sn-comment-border': 'hsla(var(--sn-hue-accent), 80%, 50%, 0.12)',
96
- '--sn-comment-radius': '6px',
97
-
98
- // Toolbar — dark glass with neon edge
99
- '--sn-toolbar-bg': 'hsla(var(--sn-hue-base), var(--sn-sat), 6%, var(--sn-alpha-overlay))',
100
- '--sn-toolbar-border': 'hsla(var(--sn-hue-accent), 80%, 50%, 0.25)',
101
- '--sn-toolbar-color': 'hsl(var(--sn-hue-accent), 25%, 60%)',
102
- '--sn-toolbar-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.18)',
103
- '--sn-toolbar-active': 'hsl(var(--sn-hue-accent), 40%, var(--sn-lit-text))',
104
- '--sn-toolbar-danger': 'hsla(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent), 0.2)',
105
- '--sn-toolbar-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), 60%)',
106
-
107
- // Shape fill/stroke — neon stroke glow
108
- '--sn-shape-fill': 'var(--sn-node-bg)',
109
- '--sn-shape-stroke': 'hsl(var(--sn-hue-accent), 60%, 35%)',
110
- '--sn-shape-stroke-width': '0.5',
111
- },
112
- };
113
-
114
- /** @type {import('./Palette.js').PaletteDefinition} */
115
- export const NEON_PALETTE = {
116
- name: 'neon',
117
- colors: {
118
- '--sn-hue-base': '230',
119
- '--sn-hue-accent': '185',
120
- '--sn-hue-success': '150',
121
- '--sn-hue-warning': '50',
122
- '--sn-hue-danger': '355',
123
- '--sn-hue-data': '280',
124
- '--sn-sat': '30%',
125
- '--sn-sat-vivid': '100%',
126
- '--sn-sat-muted': '15%',
127
- '--sn-lit-bg': '4%',
128
- '--sn-lit-surface': '8%',
129
- '--sn-lit-border': '22%',
130
- '--sn-lit-hover': '14%',
131
- '--sn-lit-text': '90%',
132
- '--sn-lit-text-dim': '55%',
133
- '--sn-lit-accent': '60%',
134
- '--sn-alpha-overlay': '0.94',
135
- '--sn-alpha-subtle': '0.2',
136
- '--sn-alpha-faint': '0.06',
137
- },
138
- };
@@ -1,273 +0,0 @@
1
- /**
2
- * PCB Dark — Carbon-based theme with circuit board node styling
3
- *
4
- * Extends the Carbon neutral dark palette with PCB-inspired node shapes:
5
- * - IC chip rectangles with notch markers
6
- * - Copper-tinted traces for import connections
7
- * - Pin indicators on sockets
8
- * - CPU hub styling for high-connectivity nodes
9
- *
10
- * Background/surface/text colors match the global Carbon dashboard.
11
- *
12
- * @module symbiote-node/themes/pcb
13
- */
14
-
15
- /** @type {import('./Theme.js').ThemeDefinition} */
16
- export const PCB_DARK = {
17
- name: 'pcb-dark',
18
- tokens: {
19
- // === Base: Carbon dark palette ===
20
-
21
- // Canvas
22
- '--sn-bg': '#1a1a1a',
23
- '--sn-grid-dot': 'rgba(255, 255, 255, 0.04)',
24
- '--sn-grid-size': '20px',
25
-
26
- // Node / Panels — Carbon surfaces (keep default geometry)
27
- '--sn-node-bg': '#222222',
28
- '--sn-node-border': 'rgba(255, 255, 255, 0.12)',
29
- '--sn-node-shadow': '0 1px 4px rgba(0, 0, 0, 0.5)',
30
- '--sn-shadow-color': 'rgba(0, 0, 0, 0.5)',
31
- '--sn-node-header-bg': '#252525',
32
- '--sn-node-selected': '#d4a04a',
33
- '--sn-node-hover': '#2d2d2d',
34
-
35
- // Typography — keep default (Inter)
36
- '--sn-text': '#e0e0e0',
37
- '--sn-text-dim': '#888888',
38
-
39
- // Sockets — pin style
40
- '--sn-socket-size': '10px',
41
- '--sn-socket-border-width': '2px',
42
-
43
- // Connections — copper traces with square caps (PCB)
44
- '--sn-conn-color': '#c87533',
45
- '--sn-conn-width': '1.5',
46
- '--sn-conn-selected': '#d4a04a',
47
- '--sn-conn-linecap': 'square',
48
- '--sn-conn-linejoin': 'miter',
49
-
50
- // Connection dots — solder pads
51
- '--sn-conn-dot-fill': '#c87533',
52
- '--sn-conn-dot-stroke': '#222222',
53
- '--sn-conn-dot-stroke-width': '1',
54
- '--sn-conn-dot-r': '3.5',
55
-
56
- // Frames — subdued zones
57
- '--sn-frame-border-style': 'dashed',
58
- '--sn-frame-border-width': '1px',
59
- '--sn-frame-radius': '6px',
60
-
61
- // Category accent colors
62
- '--sn-cat-server': '#c87533', // copper — server/routing
63
- '--sn-cat-instance': '#4caf50', // green — active
64
- '--sn-cat-control': '#d4a04a', // gold — control/hub
65
- '--sn-cat-data': '#5c8dbf', // cool blue — data flow
66
- '--sn-cat-default': '#555555', // neutral
67
- // Codebase-specific categories
68
- '--sn-cat-directory': '#f0b840', // amber — folder
69
- '--sn-cat-file': '#5cb8ff', // sky blue — JS file
70
- '--sn-cat-function': '#4ade80', // green — function
71
- '--sn-cat-class': '#a78bfa', // purple — class
72
- '--sn-cat-module': '#ff6b9d', // pink — entry/index
73
- '--sn-cat-asset': '#8b8b8b', // gray — non-source asset (.css, .html, .json, .md)
74
-
75
- // Context menu — matches Carbon
76
- '--sn-ctx-bg': '#2a2a2a',
77
- '--sn-ctx-border': 'rgba(255, 255, 255, 0.1)',
78
- '--sn-ctx-color': '#e0e0e0',
79
- '--sn-ctx-hover': 'rgba(200, 117, 51, 0.15)',
80
-
81
- // Comments
82
- '--sn-comment-bg': 'rgba(255, 255, 255, 0.03)',
83
- '--sn-comment-border': 'rgba(255, 255, 255, 0.06)',
84
- '--sn-comment-radius': '2px',
85
-
86
- // Toolbar — Carbon base with copper accent
87
- '--sn-toolbar-bg': 'rgba(34, 34, 34, 0.95)',
88
- '--sn-toolbar-border': 'rgba(255, 255, 255, 0.08)',
89
- '--sn-toolbar-color': '#888888',
90
- '--sn-toolbar-hover': 'rgba(200, 117, 51, 0.18)',
91
- '--sn-toolbar-active': '#e0e0e0',
92
- '--sn-toolbar-danger': 'rgba(244, 67, 54, 0.22)',
93
- '--sn-toolbar-danger-color': '#f44336',
94
-
95
- // Shape fill/stroke
96
- '--sn-shape-fill': 'var(--sn-node-bg)',
97
- '--sn-shape-stroke': 'var(--sn-node-border)',
98
- '--sn-shape-stroke-width': '0.5',
99
-
100
- // Semantic state
101
- '--sn-danger-color': '#f44336',
102
- '--sn-success-color': '#4caf50',
103
- '--sn-warning-color': '#ff9800',
104
-
105
- // Atomic hue tokens
106
- '--sn-hue-base': '0',
107
- '--sn-hue-accent': '28',
108
- '--sn-hue-success': '122',
109
- '--sn-hue-warning': '36',
110
- '--sn-hue-danger': '4',
111
- '--sn-hue-data': '210',
112
- '--sn-sat': '0%',
113
- '--sn-sat-vivid': '50%',
114
- '--sn-sat-muted': '0%',
115
- '--sn-lit-bg': '10%',
116
- '--sn-lit-surface': '13%',
117
- '--sn-lit-border': '17%',
118
- '--sn-lit-hover': '18%',
119
- '--sn-lit-text': '88%',
120
- '--sn-lit-text-dim': '53%',
121
- '--sn-lit-accent': '55%',
122
- '--sn-alpha-overlay': '0.95',
123
- '--sn-alpha-subtle': '0.12',
124
- '--sn-alpha-faint': '0.04',
125
- },
126
-
127
- // PCB-specific CSS that can't be expressed as tokens
128
- // (pseudo-elements, structural selectors, behavioral modes)
129
- extraCSS: `
130
- /* ── IC Chip Decorations (SVG shape nodes only) ── */
131
-
132
- /* Hide Material icons only on SVG shape nodes (they use watermarks) */
133
- graph-node[data-svg-shape] .sn-node-icon {
134
- display: none;
135
- }
136
- graph-node[data-svg-shape] .sn-shape-watermark {
137
- display: none;
138
- }
139
-
140
- /* IC chip notch marker — SVG shape nodes only */
141
- graph-node[data-svg-shape]::before {
142
- content: '';
143
- position: absolute;
144
- top: -1.5px;
145
- left: 50%;
146
- transform: translateX(-50%);
147
- width: 16px;
148
- height: 4px;
149
- background: var(--sn-bg, #1a1a1a);
150
- border-radius: 0 0 4px 4px;
151
- border: 1px solid var(--sn-node-border, rgba(255,255,255,0.12));
152
- border-top: none;
153
- z-index: 1;
154
- }
155
-
156
- /* Pin markers on node sides — SVG shape nodes only */
157
- graph-node[data-svg-shape]::after {
158
- content: '';
159
- position: absolute;
160
- top: 50%;
161
- left: -5px;
162
- width: 4px;
163
- height: 4px;
164
- background: var(--sn-conn-color, #c87533);
165
- border-radius: 50%;
166
- transform: translateY(-50%);
167
- box-shadow: calc(100% + 6px) 0 0 0 var(--sn-conn-color, #c87533);
168
- }
169
-
170
- /* ── Label Visibility Modes ── */
171
-
172
- /* SVG shape label positioning */
173
- graph-node[data-svg-shape] .sn-node-header {
174
- position: absolute;
175
- top: 50%;
176
- left: 50%;
177
- transform: translate(-50%, -50%);
178
- background: transparent;
179
- border: none;
180
- border-radius: 0;
181
- border-bottom: none;
182
- padding: 4px 10px;
183
- white-space: nowrap;
184
- opacity: 1;
185
- pointer-events: none;
186
- z-index: 1;
187
- font-size: 11px;
188
- letter-spacing: 0.3px;
189
- transition: opacity 0.2s ease-in-out;
190
- }
191
-
192
- /* HOVER MODE */
193
- node-canvas[data-label-mode="hover"] graph-node[data-svg-shape] .sn-node-header {
194
- opacity: 0;
195
- }
196
- node-canvas[data-label-mode="hover"] graph-node[data-svg-shape]:hover .sn-node-header,
197
- node-canvas[data-label-mode="hover"] graph-node[data-svg-shape][data-selected] .sn-node-header,
198
- node-canvas[data-label-mode="hover"] graph-node[data-svg-shape][data-neighbor-focused] .sn-node-header {
199
- opacity: 1;
200
- }
201
-
202
- /* FOCUS MODE */
203
- node-canvas[data-label-mode="focus"] graph-node[data-svg-shape] .sn-node-header {
204
- opacity: 0;
205
- }
206
- node-canvas[data-label-mode="focus"] graph-node[data-svg-shape][data-selected] .sn-node-header,
207
- node-canvas[data-label-mode="focus"] graph-node[data-svg-shape][data-neighbor-focused] .sn-node-header {
208
- opacity: 1;
209
- }
210
-
211
- /* ALWAYS: selected always visible */
212
- graph-node[data-svg-shape][data-selected] .sn-node-header {
213
- opacity: 1 !important;
214
- }
215
-
216
- /* ── Connection Focus States ── */
217
-
218
- /* Selected node connections — full opacity, gold, thick */
219
- .sn-conn-path[data-active-conn] {
220
- opacity: 1 !important;
221
- stroke-width: 2.5 !important;
222
- stroke: var(--sn-node-selected, #d4a04a) !important;
223
- }
224
-
225
- /* Dim non-active connections when a node is selected */
226
- .sn-conn-path[data-dimmed] {
227
- opacity: 0.3 !important;
228
- }
229
-
230
- /* LOD: at low zoom, hide connections but keep active visible */
231
- [data-lod-dimmed] .sn-conn-path,
232
- [data-lod-dimmed] .sn-conn-arrow {
233
- visibility: hidden;
234
- }
235
- [data-lod-dimmed] .sn-conn-path[data-active-conn],
236
- [data-lod-dimmed] .sn-conn-arrow[data-active-conn] {
237
- visibility: visible;
238
- opacity: 1 !important;
239
- }
240
-
241
- /* ── Compact SVG Shape Sizing ── */
242
- graph-node[data-svg-shape] {
243
- min-width: 100px;
244
- min-height: 60px;
245
- }
246
-
247
- /* Label styling */
248
- graph-node .sn-node-label {
249
- font-weight: 500;
250
- text-shadow: 0 1px 3px rgba(0,0,0,0.6);
251
- }
252
-
253
- /* CPU hub (shield shape) — larger, gold accent labels */
254
- graph-node[node-shape="shield"] .sn-node-label {
255
- font-size: 11px;
256
- font-weight: 700;
257
- color: var(--sn-cat-control, #d4a04a);
258
- }
259
-
260
- /* Via connections: cross-directory dashed traces */
261
- .sn-conn-path[data-via] {
262
- stroke-dasharray: 6 3;
263
- opacity: 0.7;
264
- }
265
-
266
- /* Frame label styling override for PCB silkscreen look */
267
- graph-frame .sn-frame-label {
268
- text-transform: uppercase;
269
- letter-spacing: 1px;
270
- opacity: 0.6;
271
- }
272
- `,
273
- };
@@ -1,137 +0,0 @@
1
- /**
2
- * Synthwave — neon retrowave theme
3
- *
4
- * High saturation (60%), purple base hue (270).
5
- * Neon accents with vivid category colors.
6
- *
7
- * @module symbiote-node/themes/synthwave
8
- */
9
-
10
- /** @type {import('./Theme.js').ThemeDefinition} */
11
- export const SYNTHWAVE = {
12
- name: 'synthwave',
13
- tokens: {
14
- // === Atomic tokens ===
15
-
16
- // Hues
17
- '--sn-hue-base': '270',
18
- '--sn-hue-accent': '300',
19
- '--sn-hue-success': '180',
20
- '--sn-hue-warning': '60',
21
- '--sn-hue-danger': '0',
22
- '--sn-hue-data': '300',
23
-
24
- // Saturation levels (vivid neon)
25
- '--sn-sat': '45%',
26
- '--sn-sat-vivid': '100%',
27
- '--sn-sat-muted': '25%',
28
-
29
- // Lightness levels
30
- '--sn-lit-bg': '6%',
31
- '--sn-lit-surface': '12%',
32
- '--sn-lit-border': '25%',
33
- '--sn-lit-hover': '32%',
34
- '--sn-lit-text': '88%',
35
- '--sn-lit-text-dim': '48%',
36
- '--sn-lit-accent': '55%',
37
-
38
- // Alpha levels
39
- '--sn-alpha-overlay': '0.92',
40
- '--sn-alpha-subtle': '0.2',
41
- '--sn-alpha-faint': '0.08',
42
-
43
- // Semantic state colors (composed from atomics)
44
- '--sn-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent))',
45
- '--sn-success-color': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), var(--sn-lit-accent))',
46
- '--sn-warning-color': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), var(--sn-lit-accent))',
47
-
48
- // === Composed tokens ===
49
-
50
- // Canvas
51
- '--sn-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-bg))',
52
- '--sn-grid-dot': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, var(--sn-alpha-faint))',
53
- '--sn-grid-size': '24px',
54
-
55
- // Node
56
- '--sn-node-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-surface))',
57
- '--sn-node-border': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-border))',
58
- '--sn-node-radius': '12px',
59
- '--sn-node-shadow': '0 4px 20px hsla(var(--sn-hue-base), var(--sn-sat-vivid), 50%, 0.2)',
60
- '--sn-shadow-color': 'hsla(var(--sn-hue-base), var(--sn-sat-vivid), 50%, 0.2)',
61
- '--sn-node-selected': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 50%)',
62
- '--sn-node-hover': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-hover))',
63
- '--sn-node-header-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), 9%)',
64
-
65
- // Typography
66
- '--sn-font': "'Space Grotesk', sans-serif",
67
- '--sn-text': 'hsl(var(--sn-hue-base), 30%, var(--sn-lit-text))',
68
- '--sn-text-dim': 'hsl(var(--sn-hue-base), 20%, var(--sn-lit-text-dim))',
69
-
70
- // Sockets
71
- '--sn-socket-size': '14px',
72
- '--sn-socket-border-width': '2px',
73
-
74
- // Connections
75
- '--sn-conn-color': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 50%)',
76
- '--sn-conn-width': '2.5',
77
- '--sn-conn-selected': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 50%)',
78
-
79
- // Category accent colors (neon)
80
- '--sn-cat-server': 'hsl(340, 100%, 70%)',
81
- '--sn-cat-instance': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 50%)',
82
- '--sn-cat-control': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), 50%)',
83
- '--sn-cat-data': 'hsl(var(--sn-hue-data), var(--sn-sat-vivid), 50%)',
84
- '--sn-cat-default': 'hsl(var(--sn-hue-base), 20%, var(--sn-lit-text-dim))',
85
-
86
- // Context menu
87
- '--sn-ctx-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-surface))',
88
- '--sn-ctx-border': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-border))',
89
- '--sn-ctx-color': 'hsl(var(--sn-hue-base), 30%, var(--sn-lit-text))',
90
- '--sn-ctx-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, var(--sn-alpha-subtle))',
91
-
92
- // Comments
93
- '--sn-comment-bg': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.05)',
94
- '--sn-comment-border': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.15)',
95
- '--sn-comment-radius': '8px',
96
-
97
- // Toolbar
98
- '--sn-toolbar-bg': 'hsla(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-surface), var(--sn-alpha-overlay))',
99
- '--sn-toolbar-border': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.2)',
100
- '--sn-toolbar-color': 'hsl(var(--sn-hue-base), 20%, 70%)',
101
- '--sn-toolbar-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), 50%, 0.2)',
102
- '--sn-toolbar-active': 'hsl(var(--sn-hue-base), 30%, var(--sn-lit-text))',
103
- '--sn-toolbar-danger': 'hsla(var(--sn-hue-danger), var(--sn-sat-vivid), var(--sn-lit-accent), 0.25)',
104
- '--sn-toolbar-danger-color': 'hsl(var(--sn-hue-danger), 80%, 60%)',
105
-
106
- // Shape fill/stroke
107
- '--sn-shape-fill': 'var(--sn-node-bg)',
108
- '--sn-shape-stroke': 'var(--sn-node-border)',
109
- '--sn-shape-stroke-width': '0.4',
110
- },
111
- };
112
-
113
- /** @type {import('./Palette.js').PaletteDefinition} */
114
- export const SYNTHWAVE_PALETTE = {
115
- name: 'synthwave',
116
- colors: {
117
- '--sn-hue-base': '270',
118
- '--sn-hue-accent': '300',
119
- '--sn-hue-success': '180',
120
- '--sn-hue-warning': '60',
121
- '--sn-hue-danger': '0',
122
- '--sn-hue-data': '300',
123
- '--sn-sat': '45%',
124
- '--sn-sat-vivid': '100%',
125
- '--sn-sat-muted': '25%',
126
- '--sn-lit-bg': '6%',
127
- '--sn-lit-surface': '12%',
128
- '--sn-lit-border': '25%',
129
- '--sn-lit-hover': '32%',
130
- '--sn-lit-text': '88%',
131
- '--sn-lit-text-dim': '48%',
132
- '--sn-lit-accent': '55%',
133
- '--sn-alpha-overlay': '0.92',
134
- '--sn-alpha-subtle': '0.2',
135
- '--sn-alpha-faint': '0.08',
136
- },
137
- };