project-graph-mcp 2.3.1 → 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 (226) 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/index.js +0 -103
  148. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.css.js +0 -361
  149. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.js +0 -332
  150. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.tpl.js +0 -96
  151. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.css.js +0 -104
  152. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.js +0 -133
  153. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.tpl.js +0 -33
  154. package/vendor/symbiote-node/interactions/ConnectFlow.js +0 -307
  155. package/vendor/symbiote-node/interactions/Drag.js +0 -102
  156. package/vendor/symbiote-node/interactions/Selector.js +0 -132
  157. package/vendor/symbiote-node/interactions/SnapGrid.js +0 -65
  158. package/vendor/symbiote-node/interactions/Zoom.js +0 -140
  159. package/vendor/symbiote-node/layout/ActionZone/ActionZone.css.js +0 -88
  160. package/vendor/symbiote-node/layout/ActionZone/ActionZone.js +0 -254
  161. package/vendor/symbiote-node/layout/ActionZone/ActionZone.tpl.js +0 -11
  162. package/vendor/symbiote-node/layout/Layout/Layout.css.js +0 -88
  163. package/vendor/symbiote-node/layout/Layout/Layout.js +0 -622
  164. package/vendor/symbiote-node/layout/Layout/Layout.tpl.js +0 -25
  165. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.css.js +0 -293
  166. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.js +0 -467
  167. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.tpl.js +0 -33
  168. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.css.js +0 -46
  169. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.js +0 -102
  170. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.tpl.js +0 -6
  171. package/vendor/symbiote-node/layout/LayoutRouter/LayoutRouter.js +0 -156
  172. package/vendor/symbiote-node/layout/LayoutRouter/routerSync.js +0 -250
  173. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.css.js +0 -379
  174. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.js +0 -263
  175. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.tpl.js +0 -20
  176. package/vendor/symbiote-node/layout/LayoutSidebar/SidebarSection.js +0 -183
  177. package/vendor/symbiote-node/layout/LayoutTree.js +0 -246
  178. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.css.js +0 -43
  179. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.js +0 -89
  180. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.tpl.js +0 -14
  181. package/vendor/symbiote-node/layout/index.js +0 -16
  182. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.css.js +0 -61
  183. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.js +0 -79
  184. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.tpl.js +0 -19
  185. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.css.js +0 -41
  186. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.js +0 -24
  187. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.tpl.js +0 -16
  188. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.css.js +0 -65
  189. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.js +0 -29
  190. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.tpl.js +0 -13
  191. package/vendor/symbiote-node/node/GraphNode/GraphNode.css.js +0 -683
  192. package/vendor/symbiote-node/node/GraphNode/GraphNode.js +0 -92
  193. package/vendor/symbiote-node/node/GraphNode/GraphNode.tpl.js +0 -17
  194. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.js +0 -25
  195. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.tpl.js +0 -7
  196. package/vendor/symbiote-node/node/PortItem/PortItem.css.js +0 -90
  197. package/vendor/symbiote-node/node/PortItem/PortItem.js +0 -87
  198. package/vendor/symbiote-node/node/PortItem/PortItem.tpl.js +0 -10
  199. package/vendor/symbiote-node/package.json +0 -59
  200. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.css.js +0 -143
  201. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.js +0 -131
  202. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.tpl.js +0 -16
  203. package/vendor/symbiote-node/plugins/History.js +0 -384
  204. package/vendor/symbiote-node/plugins/Readonly.js +0 -59
  205. package/vendor/symbiote-node/shapes/CircleShape.js +0 -80
  206. package/vendor/symbiote-node/shapes/CommentShape.js +0 -35
  207. package/vendor/symbiote-node/shapes/DiamondShape.js +0 -115
  208. package/vendor/symbiote-node/shapes/NodeShape.js +0 -80
  209. package/vendor/symbiote-node/shapes/PillShape.js +0 -91
  210. package/vendor/symbiote-node/shapes/RectShape.js +0 -72
  211. package/vendor/symbiote-node/shapes/SVGShape.js +0 -494
  212. package/vendor/symbiote-node/shapes/index.js +0 -53
  213. package/vendor/symbiote-node/themes/Palette.js +0 -32
  214. package/vendor/symbiote-node/themes/Skin.js +0 -113
  215. package/vendor/symbiote-node/themes/Theme.js +0 -84
  216. package/vendor/symbiote-node/themes/carbon.js +0 -137
  217. package/vendor/symbiote-node/themes/dark.js +0 -137
  218. package/vendor/symbiote-node/themes/ebook.js +0 -138
  219. package/vendor/symbiote-node/themes/grey.js +0 -137
  220. package/vendor/symbiote-node/themes/light.js +0 -137
  221. package/vendor/symbiote-node/themes/neon.js +0 -138
  222. package/vendor/symbiote-node/themes/pcb.js +0 -273
  223. package/vendor/symbiote-node/themes/synthwave.js +0 -137
  224. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.css.js +0 -86
  225. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.js +0 -128
  226. 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
- };