project-graph-mcp 2.3.2 → 2.4.1

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,84 +0,0 @@
1
- /**
2
- * Theme — JSON-driven CSS token system for node graph styling
3
- *
4
- * Applies design tokens as CSS custom properties on a target element.
5
- * Themes are plain objects — AI can generate them on the fly.
6
- *
7
- * @module symbiote-node/themes/Theme
8
- */
9
-
10
- /**
11
- * @typedef {Object} ThemeDefinition
12
- * @property {string} name - Theme identifier
13
- * @property {Object<string, string>} tokens - CSS custom property key-value pairs
14
- */
15
-
16
- // Re-export all built-in themes
17
- export { DARK_DEFAULT } from './dark.js';
18
- export { LIGHT_CLEAN } from './light.js';
19
- export { SYNTHWAVE } from './synthwave.js';
20
- export { GREY_NEUTRAL } from './grey.js';
21
- export { NEON_GLOW } from './neon.js';
22
-
23
- /**
24
- * Mapping from layout global tokens to symbiote-node tokens.
25
- * Layout module uses --bg-*, --text-* format; this bridges them.
26
- * @type {Object<string, string>}
27
- */
28
- const LAYOUT_TOKEN_MAP = {
29
- '--bg-panel': '--sn-node-bg',
30
- '--bg-deeper': '--sn-bg',
31
- '--bg-header': '--sn-node-header-bg',
32
- '--bg-hover': '--sn-node-hover',
33
- '--bg-popup': '--sn-ctx-bg',
34
- '--text-main': '--sn-text',
35
- '--text-dim': '--sn-text-dim',
36
- '--text-muted': '--sn-text-dim',
37
- '--layout-border': '--sn-node-border',
38
- '--layout-highlight': '--sn-node-selected',
39
- '--border-popup': '--sn-ctx-border',
40
- '--accent': '--sn-node-selected',
41
- '--font-main': '--sn-font',
42
- };
43
-
44
- /**
45
- * Apply a theme to a DOM element
46
- * @param {HTMLElement} element
47
- * @param {ThemeDefinition} theme
48
- */
49
- export function applyTheme(element, theme) {
50
- for (const [key, value] of Object.entries(theme.tokens)) {
51
- element.style.setProperty(key, value);
52
- }
53
- // Bridge: derive global layout tokens from --sn-* values
54
- for (const [layoutToken, snToken] of Object.entries(LAYOUT_TOKEN_MAP)) {
55
- const value = theme.tokens[snToken];
56
- if (value) {
57
- element.style.setProperty(layoutToken, value);
58
- }
59
- }
60
- // Extra CSS: inject theme-specific style overrides
61
- if (theme.extraCSS) {
62
- const existing = element.querySelector('style[data-theme]');
63
- if (existing) existing.remove();
64
- const style = document.createElement('style');
65
- style.setAttribute('data-theme', theme.name || 'custom');
66
- style.textContent = theme.extraCSS;
67
- element.prepend(style);
68
- }
69
- }
70
-
71
- /**
72
- * Extract current theme tokens from an element
73
- * @param {HTMLElement} element
74
- * @param {ThemeDefinition} reference - reference theme for token keys
75
- * @returns {ThemeDefinition}
76
- */
77
- export function extractTheme(element, reference) {
78
- const tokens = {};
79
- const computed = getComputedStyle(element);
80
- for (const key of Object.keys(reference.tokens)) {
81
- tokens[key] = computed.getPropertyValue(key).trim() || reference.tokens[key];
82
- }
83
- return { name: 'extracted', tokens };
84
- }
@@ -1,137 +0,0 @@
1
- /**
2
- * Carbon — professional dark theme for code analysis
3
- *
4
- * Deep neutral greys with blue accent. Zero-saturation base
5
- * for maximum readability. Matches studio-grade tooling aesthetic.
6
- *
7
- * @module symbiote-node/themes/carbon
8
- */
9
-
10
- /** @type {import('./Theme.js').ThemeDefinition} */
11
- export const CARBON = {
12
- name: 'carbon',
13
- tokens: {
14
- // === Atomic tokens ===
15
-
16
- // Hues
17
- '--sn-hue-base': '0',
18
- '--sn-hue-accent': '218',
19
- '--sn-hue-success': '122',
20
- '--sn-hue-warning': '36',
21
- '--sn-hue-danger': '4',
22
- '--sn-hue-data': '265',
23
-
24
- // Saturation levels (achromatic base, vivid accents)
25
- '--sn-sat': '0%',
26
- '--sn-sat-vivid': '55%',
27
- '--sn-sat-muted': '0%',
28
-
29
- // Lightness levels
30
- '--sn-lit-bg': '10%', // #1a1a1a
31
- '--sn-lit-surface': '13%', // #222222
32
- '--sn-lit-border': '17%', // ~#2b2b2b
33
- '--sn-lit-hover': '27%', // #444444
34
- '--sn-lit-text': '94%', // #f0f0f0
35
- '--sn-lit-text-dim': '60%', // #999999
36
- '--sn-lit-accent': '63%', // blue accent
37
-
38
- // Alpha levels
39
- '--sn-alpha-overlay': '0.95',
40
- '--sn-alpha-subtle': '0.15',
41
- '--sn-alpha-faint': '0.06',
42
-
43
- // Semantic state colors
44
- '--sn-danger-color': '#f44336',
45
- '--sn-success-color': '#4caf50',
46
- '--sn-warning-color': '#ff9800',
47
-
48
- // === Composed tokens ===
49
-
50
- // Canvas
51
- '--sn-bg': '#1a1a1a',
52
- '--sn-grid-dot': 'rgba(255, 255, 255, 0.06)',
53
- '--sn-grid-size': '20px',
54
-
55
- // Node / Panels
56
- '--sn-node-bg': '#222222',
57
- '--sn-node-border': 'rgba(255, 255, 255, 0.1)',
58
- '--sn-node-radius': '6px',
59
- '--sn-node-shadow': '0 2px 8px rgba(0, 0, 0, 0.4)',
60
- '--sn-shadow-color': 'rgba(0, 0, 0, 0.4)',
61
- '--sn-node-header-bg': '#222222',
62
- '--sn-node-selected': '#4c8bf5',
63
- '--sn-node-hover': '#444444',
64
-
65
- // Typography
66
- '--sn-font': "'Inter', -apple-system, BlinkMacSystemFont, sans-serif",
67
- '--sn-text': '#f0f0f0',
68
- '--sn-text-dim': '#999999',
69
-
70
- // Sockets
71
- '--sn-socket-size': '12px',
72
- '--sn-socket-border-width': '2px',
73
-
74
- // Connections
75
- '--sn-conn-color': '#4c8bf5',
76
- '--sn-conn-width': '2',
77
- '--sn-conn-selected': '#f44336',
78
-
79
- // Category accent colors
80
- '--sn-cat-server': '#4c8bf5',
81
- '--sn-cat-instance': '#4caf50',
82
- '--sn-cat-control': '#ff9800',
83
- '--sn-cat-data': '#9c27b0',
84
- '--sn-cat-default': '#666666',
85
-
86
- // Context menu
87
- '--sn-ctx-bg': '#2a2a2a',
88
- '--sn-ctx-border': 'rgba(255, 255, 255, 0.1)',
89
- '--sn-ctx-color': '#f0f0f0',
90
- '--sn-ctx-hover': 'rgba(76, 139, 245, 0.15)',
91
-
92
- // Comments
93
- '--sn-comment-bg': 'rgba(255, 255, 255, 0.04)',
94
- '--sn-comment-border': 'rgba(255, 255, 255, 0.08)',
95
- '--sn-comment-radius': '4px',
96
-
97
- // Toolbar
98
- '--sn-toolbar-bg': 'rgba(34, 34, 34, 0.95)',
99
- '--sn-toolbar-border': 'rgba(255, 255, 255, 0.08)',
100
- '--sn-toolbar-color': '#999999',
101
- '--sn-toolbar-hover': 'rgba(76, 139, 245, 0.18)',
102
- '--sn-toolbar-active': '#f0f0f0',
103
- '--sn-toolbar-danger': 'rgba(244, 67, 54, 0.22)',
104
- '--sn-toolbar-danger-color': '#f44336',
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 CARBON_PALETTE = {
115
- name: 'carbon',
116
- colors: {
117
- '--sn-hue-base': '0',
118
- '--sn-hue-accent': '218',
119
- '--sn-hue-success': '122',
120
- '--sn-hue-warning': '36',
121
- '--sn-hue-danger': '4',
122
- '--sn-hue-data': '265',
123
- '--sn-sat': '0%',
124
- '--sn-sat-vivid': '55%',
125
- '--sn-sat-muted': '0%',
126
- '--sn-lit-bg': '10%',
127
- '--sn-lit-surface': '13%',
128
- '--sn-lit-border': '17%',
129
- '--sn-lit-hover': '27%',
130
- '--sn-lit-text': '94%',
131
- '--sn-lit-text-dim': '60%',
132
- '--sn-lit-accent': '63%',
133
- '--sn-alpha-overlay': '0.95',
134
- '--sn-alpha-subtle': '0.15',
135
- '--sn-alpha-faint': '0.06',
136
- },
137
- };
@@ -1,137 +0,0 @@
1
- /**
2
- * Dark Default — deep navy theme with blue accents
3
- *
4
- * Built on atomic HSL tokens: change a hue value and entire
5
- * palette rebuilds harmoniously. AI-agent friendly.
6
- *
7
- * @module symbiote-node/themes/dark
8
- */
9
-
10
- /** @type {import('./Theme.js').ThemeDefinition} */
11
- export const DARK_DEFAULT = {
12
- name: 'dark-default',
13
- tokens: {
14
- // === Atomic tokens (AI changes these) ===
15
-
16
- // Hues
17
- '--sn-hue-base': '230',
18
- '--sn-hue-accent': '215',
19
- '--sn-hue-success': '142',
20
- '--sn-hue-warning': '43',
21
- '--sn-hue-danger': '0',
22
- '--sn-hue-data': '262',
23
-
24
- // Saturation levels
25
- '--sn-sat': '30%',
26
- '--sn-sat-vivid': '60%',
27
- '--sn-sat-muted': '15%',
28
-
29
- // Lightness levels
30
- '--sn-lit-bg': '12%',
31
- '--sn-lit-surface': '18%',
32
- '--sn-lit-border': '22%',
33
- '--sn-lit-hover': '28%',
34
- '--sn-lit-text': '89%',
35
- '--sn-lit-text-dim': '63%',
36
- '--sn-lit-accent': '65%',
37
-
38
- // Alpha levels
39
- '--sn-alpha-overlay': '0.92',
40
- '--sn-alpha-subtle': '0.15',
41
- '--sn-alpha-faint': '0.06',
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 (auto from atomics) ===
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%, 100%, var(--sn-alpha-faint))',
53
- '--sn-grid-size': '20px',
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': '10px',
59
- '--sn-node-shadow': '0 4px 16px rgba(0, 0, 0, 0.3)',
60
- '--sn-shadow-color': 'rgba(0, 0, 0, 0.3)',
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), 15%)',
64
-
65
- // Typography
66
- '--sn-font': "'Inter', sans-serif",
67
- '--sn-text': 'hsl(var(--sn-hue-base), 15%, var(--sn-lit-text))',
68
- '--sn-text-dim': 'hsl(var(--sn-hue-base), 15%, 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), var(--sn-lit-accent))',
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), var(--sn-lit-accent))',
84
- '--sn-cat-default': 'hsl(0, 0%, var(--sn-lit-text-dim))',
85
-
86
- // Context menu
87
- '--sn-ctx-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), 15%)',
88
- '--sn-ctx-border': 'hsl(var(--sn-hue-base), var(--sn-sat-muted), var(--sn-lit-hover))',
89
- '--sn-ctx-color': 'hsl(0, 0%, 88%)',
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%, 100%, 0.05)',
94
- '--sn-comment-border': 'hsla(0, 0%, 100%, 0.1)',
95
- '--sn-comment-radius': '6px',
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(0, 0%, 100%, 0.1)',
100
- '--sn-toolbar-color': 'hsl(var(--sn-hue-base), 12%, 77%)',
101
- '--sn-toolbar-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent), 0.2)',
102
- '--sn-toolbar-active': 'hsl(0, 0%, 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), var(--sn-sat-vivid), var(--sn-lit-accent))',
105
-
106
- // Shape fill/stroke (inherits node tokens, per-shape override possible)
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 DARK_PALETTE = {
115
- name: 'dark',
116
- colors: {
117
- '--sn-hue-base': '230',
118
- '--sn-hue-accent': '215',
119
- '--sn-hue-success': '142',
120
- '--sn-hue-warning': '43',
121
- '--sn-hue-danger': '0',
122
- '--sn-hue-data': '262',
123
- '--sn-sat': '30%',
124
- '--sn-sat-vivid': '60%',
125
- '--sn-sat-muted': '15%',
126
- '--sn-lit-bg': '12%',
127
- '--sn-lit-surface': '18%',
128
- '--sn-lit-border': '22%',
129
- '--sn-lit-hover': '28%',
130
- '--sn-lit-text': '89%',
131
- '--sn-lit-text-dim': '63%',
132
- '--sn-lit-accent': '65%',
133
- '--sn-alpha-overlay': '0.92',
134
- '--sn-alpha-subtle': '0.15',
135
- '--sn-alpha-faint': '0.06',
136
- },
137
- };
@@ -1,138 +0,0 @@
1
- /**
2
- * E-Book — warm paper reading theme
3
- *
4
- * Inspired by e-reader displays: warm cream background,
5
- * high-contrast dark text, minimal UI chrome, serif-influenced typography.
6
- * Optimized for long reading sessions and code exploration.
7
- *
8
- * @module symbiote-node/themes/ebook
9
- */
10
-
11
- /** @type {import('./Theme.js').ThemeDefinition} */
12
- export const EBOOK = {
13
- name: 'ebook',
14
- tokens: {
15
- // === Atomic tokens ===
16
-
17
- // Hues — warm, muted palette
18
- '--sn-hue-base': '35',
19
- '--sn-hue-accent': '210',
20
- '--sn-hue-success': '150',
21
- '--sn-hue-warning': '38',
22
- '--sn-hue-danger': '4',
23
- '--sn-hue-data': '250',
24
-
25
- // Saturation — deliberately low for reading comfort
26
- '--sn-sat': '20%',
27
- '--sn-sat-vivid': '55%',
28
- '--sn-sat-muted': '12%',
29
-
30
- // Lightness — warm paper tones
31
- '--sn-lit-bg': '93%',
32
- '--sn-lit-surface': '97%',
33
- '--sn-lit-border': '82%',
34
- '--sn-lit-hover': '89%',
35
- '--sn-lit-text': '15%',
36
- '--sn-lit-text-dim': '42%',
37
- '--sn-lit-accent': '42%',
38
-
39
- // Alpha
40
- '--sn-alpha-overlay': '0.96',
41
- '--sn-alpha-subtle': '0.08',
42
- '--sn-alpha-faint': '0.06',
43
-
44
- // Semantic state colors
45
- '--sn-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), 48%)',
46
- '--sn-success-color': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 38%)',
47
- '--sn-warning-color': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), 42%)',
48
-
49
- // === Composed tokens ===
50
-
51
- // Canvas — warm cream paper
52
- '--sn-bg': 'hsl(37, 30%, 91%)',
53
- '--sn-grid-dot': 'hsla(35, 15%, 50%, 0.12)',
54
- '--sn-grid-size': '20px',
55
-
56
- // Node — slightly lighter paper surface
57
- '--sn-node-bg': 'hsl(40, 33%, 96%)',
58
- '--sn-node-border': 'hsl(35, 18%, 80%)',
59
- '--sn-node-radius': '8px',
60
- '--sn-node-shadow': '0 1px 4px rgba(100, 80, 40, 0.08)',
61
- '--sn-shadow-color': 'rgba(100, 80, 40, 0.1)',
62
- '--sn-node-selected': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent))',
63
- '--sn-node-hover': 'hsl(36, 22%, 88%)',
64
- '--sn-node-header-bg': 'hsl(37, 25%, 93%)',
65
-
66
- // Typography — serif-influenced, ink-dark
67
- '--sn-font': "'Georgia', 'Palatino', 'Times New Roman', serif",
68
- '--sn-text': 'hsl(30, 15%, 18%)',
69
- '--sn-text-dim': 'hsl(30, 10%, 45%)',
70
-
71
- // Sockets
72
- '--sn-socket-size': '12px',
73
- '--sn-socket-border-width': '2px',
74
-
75
- // Connections — subdued ink blue
76
- '--sn-conn-color': 'hsl(210, 40%, 50%)',
77
- '--sn-conn-width': '1.5',
78
- '--sn-conn-selected': 'hsl(4, 55%, 50%)',
79
-
80
- // Categories — muted, book-like accents
81
- '--sn-cat-server': 'hsl(210, 45%, 45%)',
82
- '--sn-cat-instance': 'hsl(150, 40%, 38%)',
83
- '--sn-cat-control': 'hsl(35, 50%, 45%)',
84
- '--sn-cat-data': 'hsl(250, 35%, 50%)',
85
- '--sn-cat-default': 'hsl(30, 8%, 48%)',
86
-
87
- // Context menu
88
- '--sn-ctx-bg': 'hsl(40, 30%, 96%)',
89
- '--sn-ctx-border': 'hsl(35, 15%, 82%)',
90
- '--sn-ctx-color': 'hsl(30, 12%, 20%)',
91
- '--sn-ctx-hover': 'hsla(210, 40%, 50%, 0.08)',
92
-
93
- // Comments — faded parchment
94
- '--sn-comment-bg': 'hsla(38, 25%, 85%, 0.3)',
95
- '--sn-comment-border': 'hsla(35, 20%, 70%, 0.2)',
96
- '--sn-comment-radius': '4px',
97
-
98
- // Toolbar
99
- '--sn-toolbar-bg': 'hsla(40, 30%, 95%, var(--sn-alpha-overlay))',
100
- '--sn-toolbar-border': 'hsla(35, 15%, 70%, 0.25)',
101
- '--sn-toolbar-color': 'hsl(30, 10%, 35%)',
102
- '--sn-toolbar-hover': 'hsla(210, 40%, 50%, 0.1)',
103
- '--sn-toolbar-active': 'hsl(30, 12%, 20%)',
104
- '--sn-toolbar-danger': 'hsla(4, 55%, 50%, 0.1)',
105
- '--sn-toolbar-danger-color': 'hsl(4, 55%, 50%)',
106
-
107
- // Shape
108
- '--sn-shape-fill': 'var(--sn-node-bg)',
109
- '--sn-shape-stroke': 'var(--sn-node-border)',
110
- '--sn-shape-stroke-width': '1.0',
111
- },
112
- };
113
-
114
- /** @type {import('./Palette.js').PaletteDefinition} */
115
- export const EBOOK_PALETTE = {
116
- name: 'ebook',
117
- colors: {
118
- '--sn-hue-base': '35',
119
- '--sn-hue-accent': '210',
120
- '--sn-hue-success': '150',
121
- '--sn-hue-warning': '38',
122
- '--sn-hue-danger': '4',
123
- '--sn-hue-data': '250',
124
- '--sn-sat': '20%',
125
- '--sn-sat-vivid': '55%',
126
- '--sn-sat-muted': '12%',
127
- '--sn-lit-bg': '93%',
128
- '--sn-lit-surface': '97%',
129
- '--sn-lit-border': '82%',
130
- '--sn-lit-hover': '89%',
131
- '--sn-lit-text': '15%',
132
- '--sn-lit-text-dim': '42%',
133
- '--sn-lit-accent': '42%',
134
- '--sn-alpha-overlay': '0.96',
135
- '--sn-alpha-subtle': '0.08',
136
- '--sn-alpha-faint': '0.06',
137
- },
138
- };
@@ -1,137 +0,0 @@
1
- /**
2
- * Grey Neutral — professional muted grey theme
3
- *
4
- * Zero saturation base (achromatic). All variation through
5
- * lightness only. Category accents retain color.
6
- *
7
- * @module symbiote-node/themes/grey
8
- */
9
-
10
- /** @type {import('./Theme.js').ThemeDefinition} */
11
- export const GREY_NEUTRAL = {
12
- name: 'grey-neutral',
13
- tokens: {
14
- // === Atomic tokens ===
15
-
16
- // Hues (base is neutral — sat=0 makes hue irrelevant)
17
- '--sn-hue-base': '0',
18
- '--sn-hue-accent': '207',
19
- '--sn-hue-success': '136',
20
- '--sn-hue-warning': '40',
21
- '--sn-hue-danger': '7',
22
- '--sn-hue-data': '265',
23
-
24
- // Saturation levels (achromatic base)
25
- '--sn-sat': '0%',
26
- '--sn-sat-vivid': '50%',
27
- '--sn-sat-muted': '0%',
28
-
29
- // Lightness levels
30
- '--sn-lit-bg': '18%',
31
- '--sn-lit-surface': '24%',
32
- '--sn-lit-border': '33%',
33
- '--sn-lit-hover': '29%',
34
- '--sn-lit-text': '83%',
35
- '--sn-lit-text-dim': '63%',
36
- '--sn-lit-accent': '65%',
37
-
38
- // Alpha levels
39
- '--sn-alpha-overlay': '0.94',
40
- '--sn-alpha-subtle': '0.15',
41
- '--sn-alpha-faint': '0.1',
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 (auto from atomics) ===
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%, 100%, var(--sn-alpha-faint))',
53
- '--sn-grid-size': '20px',
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), var(--sn-lit-border))',
58
- '--sn-node-radius': '6px',
59
- '--sn-node-shadow': '0 2px 8px rgba(0, 0, 0, 0.4)',
60
- '--sn-shadow-color': 'rgba(0, 0, 0, 0.4)',
61
- '--sn-node-header-bg': 'hsl(var(--sn-hue-base), var(--sn-sat), 20%)',
62
- '--sn-node-selected': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent))',
63
- '--sn-node-hover': 'hsl(var(--sn-hue-base), var(--sn-sat), var(--sn-lit-hover))',
64
-
65
- // Typography
66
- '--sn-font': "'Inter', sans-serif",
67
- '--sn-text': 'hsl(0, 0%, var(--sn-lit-text))',
68
- '--sn-text-dim': 'hsl(0, 0%, 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(0, 0%, 54%)',
76
- '--sn-conn-width': '2',
77
- '--sn-conn-selected': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), 60%)',
78
-
79
- // Category accent colors (retain color in grey theme)
80
- '--sn-cat-server': 'hsl(var(--sn-hue-accent), var(--sn-sat-vivid), 68%)',
81
- '--sn-cat-instance': 'hsl(var(--sn-hue-success), var(--sn-sat-vivid), 58%)',
82
- '--sn-cat-control': 'hsl(var(--sn-hue-warning), var(--sn-sat-vivid), 60%)',
83
- '--sn-cat-data': 'hsl(var(--sn-hue-data), var(--sn-sat-vivid), 68%)',
84
- '--sn-cat-default': 'hsl(0, 0%, 60%)',
85
-
86
- // Context menu
87
- '--sn-ctx-bg': 'hsl(0, 0%, 22%)',
88
- '--sn-ctx-border': 'hsl(0, 0%, var(--sn-lit-border))',
89
- '--sn-ctx-color': 'hsl(0, 0%, 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%, 100%, 0.04)',
94
- '--sn-comment-border': 'hsla(0, 0%, 100%, 0.08)',
95
- '--sn-comment-radius': '4px',
96
-
97
- // Toolbar
98
- '--sn-toolbar-bg': 'hsla(0, 0%, 22%, var(--sn-alpha-overlay))',
99
- '--sn-toolbar-border': 'hsla(0, 0%, 100%, 0.08)',
100
- '--sn-toolbar-color': 'hsl(0, 0%, 67%)',
101
- '--sn-toolbar-hover': 'hsla(var(--sn-hue-accent), var(--sn-sat-vivid), var(--sn-lit-accent), 0.18)',
102
- '--sn-toolbar-active': 'hsl(0, 0%, var(--sn-lit-text))',
103
- '--sn-toolbar-danger': 'hsla(var(--sn-hue-danger), var(--sn-sat-vivid), 60%, 0.22)',
104
- '--sn-toolbar-danger-color': 'hsl(var(--sn-hue-danger), var(--sn-sat-vivid), 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 GREY_PALETTE = {
115
- name: 'grey',
116
- colors: {
117
- '--sn-hue-base': '0',
118
- '--sn-hue-accent': '207',
119
- '--sn-hue-success': '136',
120
- '--sn-hue-warning': '40',
121
- '--sn-hue-danger': '7',
122
- '--sn-hue-data': '265',
123
- '--sn-sat': '0%',
124
- '--sn-sat-vivid': '50%',
125
- '--sn-sat-muted': '0%',
126
- '--sn-lit-bg': '18%',
127
- '--sn-lit-surface': '24%',
128
- '--sn-lit-border': '33%',
129
- '--sn-lit-hover': '29%',
130
- '--sn-lit-text': '83%',
131
- '--sn-lit-text-dim': '63%',
132
- '--sn-lit-accent': '65%',
133
- '--sn-alpha-overlay': '0.94',
134
- '--sn-alpha-subtle': '0.15',
135
- '--sn-alpha-faint': '0.1',
136
- },
137
- };