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,683 +0,0 @@
1
- import { css } from '@symbiotejs/symbiote';
2
-
3
- export const styles = css`
4
- graph-node {
5
- display: block;
6
- min-width: var(--sn-node-min-width, 180px);
7
- max-width: var(--sn-node-max-width, 280px);
8
- border-radius: var(--sn-node-radius, 10px);
9
- background: var(--sn-node-bg, #16213e);
10
- border: var(--sn-node-border-width, 2px) solid var(--sn-node-border, #2a2a4a);
11
- box-shadow: var(--sn-node-shadow, 0 4px 16px var(--sn-shadow-color, rgba(0, 0, 0, 0.3)));
12
- user-select: none;
13
- cursor: move;
14
- transition: border-color 0.2s ease-out, box-shadow 0.2s ease-out, opacity 0.2s ease-out;
15
- overflow: visible;
16
- font-family: var(--sn-font, 'Inter', sans-serif);
17
- font-size: var(--sn-node-font-size, 13px);
18
- -webkit-font-smoothing: antialiased;
19
-
20
- /* Symbiote animateOut: CSS-driven exit transition */
21
- &[leaving] {
22
- opacity: 0;
23
- transform: scale(0.92);
24
- transition: border-color 0.2s ease-out, box-shadow 0.2s ease-out, opacity 0.2s ease-out, transform 0.2s ease-out;
25
- }
26
-
27
- &[data-selected] {
28
- border-color: var(--sn-node-selected, #4a9eff);
29
- box-shadow: 0 0 20px color-mix(in srgb, var(--sn-node-selected, #4a9eff) 30%, transparent);
30
- }
31
-
32
- &[data-collapsed] {
33
- & .controls {
34
- display: none;
35
- }
36
- & .sn-node-body {
37
- padding: 4px 0;
38
- }
39
- & .port-label {
40
- display: none;
41
- }
42
- }
43
-
44
- &[data-muted] {
45
- opacity: 0.45;
46
- filter: saturate(0.3);
47
-
48
- & .sn-node-label {
49
- text-decoration: line-through;
50
- }
51
- }
52
-
53
- /* Compact mode — hide node body (ports & controls).
54
- Activated by canvas.setCompactMode(true) which sets data-compact on the canvas.
55
- SubgraphNodes (node-type="subgraph") keep body visible for inner graph preview. */
56
- node-canvas[data-compact] &:not([node-type="subgraph"]) .sn-node-body {
57
- display: none;
58
- }
59
-
60
- /* LOD: medium — strip heavy rendering for performance */
61
- &[data-lod="medium"] {
62
- box-shadow: none;
63
- transition: none;
64
- will-change: auto;
65
- pointer-events: auto;
66
-
67
- &:hover {
68
- border-color: var(--sn-node-border, #2a2a4a);
69
- }
70
-
71
- &[data-selected] {
72
- box-shadow: none;
73
- }
74
-
75
- &[data-processing] {
76
- box-shadow: none;
77
- animation: none;
78
- }
79
-
80
- &[data-completed] {
81
- box-shadow: none;
82
- }
83
-
84
- &[data-muted] {
85
- filter: none;
86
- opacity: 0.5;
87
- }
88
-
89
- & .controls,
90
- & .port-label,
91
- & .sn-subgraph-preview,
92
- & .error-frame,
93
- & .sn-quick-toolbar {
94
- display: none;
95
- }
96
-
97
- & .sn-node-body {
98
- padding: 2px 0;
99
- }
100
-
101
- & node-socket {
102
- transition: none;
103
- cursor: default;
104
-
105
- &:hover {
106
- transform: none;
107
- box-shadow: none;
108
- }
109
- }
110
- }
111
-
112
-
113
- &[node-type="subgraph"] .sn-subgraph-preview {
114
- display: block;
115
- width: 100%;
116
- height: 80px;
117
- border-top: 1px solid color-mix(in srgb, currentColor 6%, transparent);
118
- opacity: 0.7;
119
- }
120
-
121
- &[data-processing] {
122
- border-color: var(--sn-node-accent, var(--sn-node-selected, #4a9eff));
123
- box-shadow: 0 0 16px color-mix(in srgb, var(--sn-node-accent, #4a9eff) 40%, transparent),
124
- 0 0 4px color-mix(in srgb, var(--sn-node-accent, #4a9eff) 60%, transparent);
125
- animation: sn-node-pulse 1s ease-in-out infinite;
126
- }
127
-
128
- &[data-completed] {
129
- border-color: var(--sn-success-color, #5cd87a);
130
- box-shadow: 0 0 8px color-mix(in srgb, var(--sn-success-color, #5cd87a) 30%, transparent);
131
- }
132
-
133
- &[data-error] {
134
- border-color: color-mix(in srgb, var(--sn-danger-color, #ef4444) 60%, transparent);
135
- position: relative;
136
- }
137
-
138
- &[data-error] .sn-node-header {
139
- background: color-mix(in srgb, var(--sn-danger-color, #ef4444) 10%, transparent);
140
- }
141
-
142
- & .error-frame {
143
- position: absolute;
144
- bottom: calc(100% + 10px);
145
- left: 50%;
146
- transform: translateX(-50%);
147
- min-width: 140px;
148
- max-width: 320px;
149
- border: 2px solid color-mix(in srgb, var(--sn-danger-color, #ef4444) 60%, transparent);
150
- border-radius: 12px;
151
- background: color-mix(in srgb, var(--sn-danger-color, #ef4444) 8%, transparent);
152
- pointer-events: none;
153
- z-index: 10;
154
- transition: bottom 0.15s ease;
155
- }
156
-
157
- & .error-frame-header {
158
- display: flex;
159
- align-items: center;
160
- gap: 6px;
161
- padding: 5px 10px;
162
- font-size: 12px;
163
- font-weight: 600;
164
- color: color-mix(in srgb, var(--sn-danger-color, #ef4444) 90%, white);
165
- border-bottom: 1px solid color-mix(in srgb, var(--sn-danger-color, #ef4444) 20%, transparent);
166
- user-select: none;
167
- }
168
-
169
- & .error-frame-header .material-symbols-outlined {
170
- font-size: 14px;
171
- opacity: 0.8;
172
- }
173
-
174
- & .error-frame-body {
175
- padding: 6px 10px;
176
- font-size: 11px;
177
- line-height: 1.4;
178
- color: color-mix(in srgb, var(--sn-danger-color, #ef4444) 75%, white);
179
- word-wrap: break-word;
180
- }
181
-
182
-
183
-
184
- &[data-selected] .error-frame {
185
- bottom: calc(100% + 46px);
186
- }
187
-
188
- &:hover {
189
- border-color: var(--sn-node-hover, #3a3a6a);
190
- }
191
-
192
- &[node-category="server"] {
193
- --sn-node-accent: var(--sn-cat-server, #4a9eff);
194
- }
195
- &[node-category="instance"] {
196
- --sn-node-accent: var(--sn-cat-instance, #4ade80);
197
- }
198
- &[node-category="control"] {
199
- --sn-node-accent: var(--sn-cat-control, #fbbf24);
200
- }
201
- &[node-category="data"] {
202
- --sn-node-accent: var(--sn-cat-data, #a78bfa);
203
- }
204
- &[node-category="default"] {
205
- --sn-node-accent: var(--sn-cat-default, #94a3b8);
206
- }
207
- /* Codebase categories */
208
- &[node-category="directory"] {
209
- --sn-node-accent: var(--sn-cat-directory, #f0b840);
210
- }
211
- &[node-category="file"] {
212
- --sn-node-accent: var(--sn-cat-file, #5cb8ff);
213
- }
214
- &[node-category="function"] {
215
- --sn-node-accent: var(--sn-cat-function, #4ade80);
216
- }
217
- &[node-category="class"] {
218
- --sn-node-accent: var(--sn-cat-class, #a78bfa);
219
- }
220
- &[node-category="module"] {
221
- --sn-node-accent: var(--sn-cat-module, #ff6b9d);
222
- }
223
-
224
- /* Shape: pill — compact horizontal capsule */
225
- &[node-shape="pill"] {
226
- min-width: 100px;
227
- max-width: 200px;
228
- border-radius: 999px;
229
-
230
- & .sn-node-header {
231
- display: none;
232
- }
233
- & .sn-node-body {
234
- padding: 8px 20px;
235
- align-items: center;
236
- justify-content: center;
237
- flex-direction: row;
238
- gap: 8px;
239
- }
240
- & .inputs, & .outputs {
241
- padding: 0;
242
- }
243
- & .sn-port-in node-socket {
244
- margin-left: -26px;
245
- }
246
- & .sn-port-out node-socket {
247
- margin-right: -26px;
248
- }
249
- & .controls {
250
- display: none;
251
- }
252
- }
253
-
254
- /* Shape: circle — hub/connector node */
255
- &[node-shape="circle"] {
256
- min-width: 100px;
257
- min-height: 100px;
258
- border-radius: 50%;
259
- aspect-ratio: 1;
260
- display: flex;
261
- flex-direction: column;
262
- align-items: center;
263
- justify-content: center;
264
-
265
- & .sn-node-header {
266
- background: transparent;
267
- border-bottom: none;
268
- justify-content: center;
269
- padding: 6px;
270
- }
271
- & .sn-node-body {
272
- padding: 0 8px 8px;
273
- flex-direction: row;
274
- align-items: center;
275
- gap: 0;
276
- }
277
- & .inputs {
278
- position: absolute;
279
- left: -6px;
280
- top: 50%;
281
- transform: translateY(-50%);
282
- }
283
- & .outputs {
284
- position: absolute;
285
- right: -6px;
286
- top: 50%;
287
- transform: translateY(-50%);
288
- }
289
- & .port-label {
290
- display: none;
291
- }
292
- & .controls {
293
- display: none;
294
- }
295
- }
296
-
297
- /* Shape: diamond — condition/decision */
298
- &[node-shape="diamond"] {
299
- min-width: 100px;
300
- min-height: 100px;
301
- border-radius: 4px;
302
- transform-origin: center;
303
- clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
304
- display: flex;
305
- align-items: center;
306
- justify-content: center;
307
-
308
- & .sn-node-header {
309
- display: none;
310
- }
311
- & .sn-node-body {
312
- text-align: center;
313
- padding: 25% 10%;
314
- }
315
- & .controls {
316
- display: none;
317
- }
318
- }
319
-
320
- /* Shape: comment — annotation banner */
321
- &[node-shape="comment"] {
322
- min-width: 200px;
323
- max-width: 400px;
324
- border-radius: var(--sn-comment-radius, 6px);
325
- background: var(--sn-comment-bg, rgba(255, 255, 255, 0.05));
326
- border-color: var(--sn-comment-border, rgba(255, 255, 255, 0.1));
327
- cursor: default;
328
- box-shadow: none;
329
-
330
- & .sn-node-header {
331
- display: none;
332
- }
333
- & .sn-node-body {
334
- padding: 12px 16px;
335
- }
336
- & .inputs, & .outputs {
337
- display: none;
338
- }
339
- }
340
-
341
- /* Shape: SVG custom — node with SVG background path */
342
- &[data-svg-shape] {
343
- position: relative;
344
- min-width: 100px;
345
- min-height: 100px;
346
- background: transparent;
347
- border: none;
348
- box-shadow: none;
349
- border-radius: 0;
350
- overflow: visible;
351
- cursor: default;
352
-
353
- /* Move cursor only over SVG path fill area */
354
- & > svg {
355
- pointer-events: none;
356
- & > path {
357
- pointer-events: visibleFill;
358
- cursor: move;
359
- transition: stroke 0.2s ease;
360
- }
361
- }
362
-
363
- & .sn-node-header {
364
- position: absolute;
365
- top: -28px;
366
- left: 50%;
367
- transform: translateX(-50%);
368
- background: var(--sn-node-header-bg, color-mix(in srgb, var(--sn-node-accent, #4a9eff) 20%, var(--sn-node-bg, #16213e)));
369
- border: 2px solid var(--sn-node-border, #2a2a4a);
370
- border-radius: 20px;
371
- padding: 3px 12px;
372
- white-space: nowrap;
373
- z-index: 1;
374
- opacity: 0;
375
- pointer-events: none;
376
- transition: opacity 0.2s ease;
377
- }
378
- &:hover .sn-node-header {
379
- opacity: 1;
380
- }
381
- &[data-selected] .sn-node-header {
382
- opacity: 0;
383
- }
384
- & .sn-node-body {
385
- padding: 4px 0;
386
- align-items: center;
387
- }
388
- & .controls {
389
- display: none;
390
- }
391
- & .sn-shape-watermark {
392
- position: absolute;
393
- top: 50%;
394
- left: 50%;
395
- transform: translate(-50%, -50%);
396
- font-size: 40px;
397
- color: var(--sn-node-accent, var(--sn-text-dim, #888));
398
- pointer-events: none;
399
- z-index: 0;
400
- }
401
- /* Hide DOM port items — ConnectionRenderer computes positions mathematically */
402
- & .inputs, & .outputs {
403
- display: none;
404
- }
405
- }
406
-
407
- /* SVG shape states — target inline svg > path directly.
408
- border/box-shadow have no effect on SVG nodes (border: none).
409
- Only stroke COLOR changes on state — width stays the same as inactive,
410
- matching HTML nodes where border-width stays 1px on selection. */
411
- &[data-svg-shape][data-selected] > svg > path {
412
- stroke: var(--sn-node-selected, #4a9eff);
413
- transition: stroke 0.2s ease;
414
- }
415
-
416
- &[data-svg-shape][data-error] > svg > path {
417
- stroke: var(--sn-danger-color, #ef4444);
418
- transition: stroke 0.2s ease;
419
- }
420
-
421
- &[data-svg-shape][data-muted] > svg > path {
422
- opacity: 0.35;
423
- filter: saturate(0.2);
424
- transition: opacity 0.2s ease, filter 0.2s ease;
425
- }
426
-
427
- &[data-svg-shape][data-processing] > svg > path {
428
- stroke: var(--sn-node-accent, var(--sn-node-selected, #4a9eff));
429
- animation: sn-svg-pulse 1s ease-in-out infinite;
430
- }
431
-
432
- &[data-svg-shape][data-completed] > svg > path {
433
- stroke: var(--sn-success-color, #5cd87a);
434
- transition: stroke 0.2s ease;
435
- }
436
-
437
- & .sn-node-header {
438
- display: flex;
439
- align-items: center;
440
- gap: 6px;
441
- padding: 8px 12px;
442
- background: var(--sn-node-header-bg, color-mix(in srgb, var(--sn-node-accent) 15%, transparent));
443
- border-bottom: 1px solid color-mix(in srgb, currentColor 6%, transparent);
444
- border-radius: var(--sn-node-radius, 10px) var(--sn-node-radius, 10px) 0 0;
445
- }
446
-
447
- & .sn-node-icon {
448
- font-size: 18px;
449
- color: var(--sn-node-accent);
450
- opacity: 1;
451
- }
452
-
453
- & .sn-node-label {
454
- font-weight: 600;
455
- font-size: var(--sn-node-label-size, inherit);
456
- color: var(--sn-text, #e2e8f0);
457
- opacity: 1;
458
- white-space: nowrap;
459
- overflow: hidden;
460
- text-overflow: ellipsis;
461
- }
462
-
463
- & .sn-node-body {
464
- padding: 8px 0;
465
- display: flex;
466
- flex-direction: column;
467
- gap: 4px;
468
- }
469
-
470
- & .inputs, & .outputs {
471
- display: flex;
472
- flex-direction: column;
473
- transition: transform 0.15s ease;
474
- }
475
-
476
- /* Port hint: slide ports to nearest side during connector drag */
477
- &[data-port-hint="right"] .inputs {
478
- transform: translateX(calc(100% - 12px));
479
- }
480
-
481
- &[data-port-hint="left"] .outputs {
482
- transform: translateX(calc(-100% + 12px));
483
- }
484
-
485
- /* Compatible SVG node during drag: subtle outline hint only — dots handle highlight */
486
- &[data-svg-shape][data-port-hint] > svg > path {
487
- stroke: var(--sn-node-selected, #4a9eff);
488
- stroke-width: 0.5;
489
- opacity: 0.8;
490
- transition: stroke 0.15s ease, opacity 0.15s ease;
491
- }
492
-
493
- /* Incompatible dimming for nodes without compatible ports */
494
- &[data-port-hint="none"] {
495
- opacity: 0.4;
496
- pointer-events: none;
497
- }
498
-
499
- & .sn-port {
500
- display: flex;
501
- align-items: center;
502
- gap: 6px;
503
- padding: 3px 12px;
504
- min-height: 24px;
505
- }
506
-
507
- & .sn-port-in {
508
- flex-direction: row;
509
-
510
- & node-socket {
511
- margin-left: -18px;
512
- }
513
- }
514
-
515
- & .sn-port-out {
516
- flex-direction: row;
517
- justify-content: flex-end;
518
-
519
- & node-socket {
520
- margin-right: -18px;
521
- }
522
- }
523
-
524
- & .port-label {
525
- color: var(--sn-text-dim, #94a3b8);
526
- font-size: 12px;
527
- white-space: nowrap;
528
- }
529
-
530
- & .controls {
531
- padding: 0 12px;
532
- }
533
-
534
- & .sn-control-item {
535
- display: flex;
536
- flex-direction: column;
537
- gap: 2px;
538
- margin: 4px 0;
539
- }
540
-
541
- & .sn-control-label {
542
- font-size: 10px;
543
- text-transform: uppercase;
544
- color: var(--sn-text-dim, #94a3b8);
545
- letter-spacing: 0.5px;
546
- }
547
-
548
- & .sn-control-input {
549
- background: rgba(0, 0, 0, 0.3);
550
- border: 1px solid color-mix(in srgb, currentColor 10%, transparent);
551
- border-radius: 4px;
552
- padding: 4px 8px;
553
- color: var(--sn-text, #e2e8f0);
554
- font-size: 12px;
555
- outline: none;
556
- font-family: 'JetBrains Mono', 'Fira Code', 'SF Mono', monospace;
557
-
558
- &:focus {
559
- border-color: var(--sn-node-accent);
560
- }
561
-
562
- &[readonly] {
563
- opacity: 0.6;
564
- cursor: default;
565
- }
566
- }
567
- }
568
-
569
- /* Preview Area — image/text preview at bottom of node */
570
- .sn-preview {
571
- border-top: 1px solid var(--sn-node-border, rgba(255, 255, 255, 0.06));
572
- border-radius: 0 0 8px 8px;
573
- overflow: hidden;
574
- max-height: 120px;
575
- background: rgba(0, 0, 0, 0.2);
576
-
577
- &[hidden] {
578
- display: none;
579
- }
580
-
581
- & img {
582
- width: 100%;
583
- height: auto;
584
- display: block;
585
- object-fit: cover;
586
- max-height: 120px;
587
- }
588
-
589
- & .sn-preview-text {
590
- padding: 6px 10px;
591
- font-size: 11px;
592
- color: var(--sn-text-dim, #94a3b8);
593
- font-family: 'JetBrains Mono', 'Fira Code', monospace;
594
- white-space: pre-wrap;
595
- word-break: break-all;
596
- line-height: 1.4;
597
- }
598
- }
599
-
600
- node-socket {
601
- display: block;
602
- width: 12px;
603
- height: 12px;
604
- border-radius: 50%;
605
- background: var(--socket-color, var(--sn-node-accent, #4a9eff));
606
- border: 2px solid var(--sn-node-bg, #16213e);
607
- cursor: crosshair;
608
- flex-shrink: 0;
609
- transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
610
- z-index: 10;
611
- position: relative;
612
-
613
- /* 44×44px invisible touch target */
614
- &::before {
615
- content: '';
616
- position: absolute;
617
- top: 50%;
618
- left: 50%;
619
- width: 44px;
620
- height: 44px;
621
- transform: translate(-50%, -50%);
622
- }
623
-
624
- &:hover {
625
- transform: scale(1.3);
626
- box-shadow: 0 0 8px var(--socket-color, var(--sn-node-accent));
627
- }
628
-
629
- /* Port shape: square — array/object types */
630
- &[data-socket-shape="square"] {
631
- border-radius: 2px;
632
- }
633
-
634
- /* Port shape: diamond — execution/trigger */
635
- &[data-socket-shape="diamond"] {
636
- border-radius: 1px;
637
- transform: rotate(45deg) scale(0.85);
638
-
639
- &:hover {
640
- transform: rotate(45deg) scale(1.1);
641
- }
642
- }
643
-
644
- /* Port shape: triangle — trigger/event */
645
- &[data-socket-shape="triangle"] {
646
- border-radius: 0;
647
- background: transparent;
648
- width: 0;
649
- height: 0;
650
- border: 6px solid transparent;
651
- border-left: 10px solid var(--socket-color, var(--sn-node-accent));
652
- border-right: none;
653
- }
654
- }
655
-
656
- @keyframes sn-node-pulse {
657
- 0%, 100% { opacity: 1; }
658
- 50% { opacity: 0.7; }
659
- }
660
-
661
- @keyframes sn-node-error-pulse {
662
- 0%, 100% { box-shadow: 0 0 16px color-mix(in srgb, var(--sn-danger-color, #ef4444) 35%, transparent), 0 0 4px color-mix(in srgb, var(--sn-danger-color, #ef4444) 50%, transparent); }
663
- 50% { box-shadow: 0 0 24px color-mix(in srgb, var(--sn-danger-color, #ef4444) 50%, transparent), 0 0 8px color-mix(in srgb, var(--sn-danger-color, #ef4444) 70%, transparent); }
664
- }
665
-
666
- @keyframes sn-svg-pulse {
667
- 0%, 100% { opacity: 0.7; transform: scale(1); }
668
- 50% { opacity: 1; transform: scale(1.05); }
669
- }
670
-
671
-
672
-
673
- /* Accessibility: reduced motion */
674
- @media (prefers-reduced-motion: reduce) {
675
- graph-node {
676
- transition: none;
677
- animation: none;
678
- }
679
- node-socket {
680
- transition: none;
681
- }
682
- }
683
- `;