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,379 +0,0 @@
1
- /**
2
- * LayoutSidebar styles
3
- * @module symbiote-node/layout/LayoutSidebar
4
- */
5
- import { css } from '@symbiotejs/symbiote';
6
-
7
- export const sidebarStyles = css`
8
- layout-sidebar {
9
- display: flex;
10
- flex-direction: column;
11
- width: 220px;
12
- min-width: 220px;
13
- background: var(--sn-bg, #1e1e1e);
14
- border-right: 1px solid var(--sn-node-border, rgba(255, 255, 255, 0.06));
15
- overflow: hidden;
16
- transition: width 0.2s ease, min-width 0.2s ease;
17
- user-select: none;
18
- position: relative;
19
-
20
- &[collapsed] {
21
- width: 48px;
22
- min-width: 48px;
23
- }
24
- }
25
-
26
- /* Resize handle — right edge */
27
- layout-sidebar .sb-resize-handle {
28
- position: absolute;
29
- top: 0;
30
- right: -2px;
31
- width: 5px;
32
- height: 100%;
33
- cursor: col-resize;
34
- z-index: 10;
35
- transition: background 0.15s;
36
-
37
- &:hover, &.dragging {
38
- background: var(--sn-node-selected, #4a9eff);
39
- opacity: 0.5;
40
- }
41
-
42
- layout-sidebar[collapsed] & {
43
- display: none;
44
- }
45
- }
46
-
47
- /* ═══════════════════════ Header — same as panel headers ═══════════════════════ */
48
- layout-sidebar .sb-header {
49
- display: flex;
50
- align-items: center;
51
- gap: 2px;
52
- padding: 2px 4px;
53
- min-height: 28px;
54
- background: var(--bg-header, var(--sn-bg, #1e1e1e));
55
- border-bottom: 1px solid var(--sn-node-border, rgba(255, 255, 255, 0.06));
56
- flex-shrink: 0;
57
-
58
- /* Collapsed: center the collapse button */
59
- layout-sidebar[collapsed] & {
60
- justify-content: center;
61
- padding: 2px 0;
62
- }
63
- }
64
-
65
- layout-sidebar .sb-header-spacer {
66
- flex: 1;
67
-
68
- layout-sidebar[collapsed] & {
69
- display: none;
70
- }
71
- }
72
-
73
- /* Header buttons — same style as panel header-btn */
74
- layout-sidebar .sb-header-btn {
75
- display: flex;
76
- align-items: center;
77
- justify-content: center;
78
- padding: 4px 6px;
79
- background: transparent;
80
- border: none;
81
- border-radius: 4px;
82
- cursor: pointer;
83
- color: var(--text-dim, var(--sn-text-dim, #888));
84
- font-size: 0.75rem;
85
- transition: background 0.1s, color 0.1s;
86
-
87
- &:hover {
88
- background: var(--bg-hover, var(--sn-node-hover, rgba(255, 255, 255, 0.06)));
89
- color: var(--text-main, var(--sn-text, #d4d4d4));
90
- }
91
-
92
- & .material-symbols-outlined {
93
- font-size: 16px;
94
- }
95
-
96
- /* Active tune button in edit mode */
97
- layout-sidebar[edit-mode] &:first-child {
98
- color: var(--sn-cat-server, #5cb8ff);
99
- background: color-mix(in srgb, var(--sn-cat-server, #5cb8ff) 10%, transparent);
100
- }
101
- }
102
-
103
- /* Hide tune button when collapsed */
104
- layout-sidebar[collapsed] .sb-header-btn:first-child {
105
- display: none;
106
- }
107
-
108
- /* Collapse icon rotation */
109
- layout-sidebar .sb-collapse-icon {
110
- transition: transform 0.2s ease;
111
- }
112
-
113
- layout-sidebar[collapsed] .sb-collapse-icon {
114
- transform: rotate(180deg);
115
- }
116
-
117
- /* ═══════════════════════ Sections container ═══════════════════════ */
118
- layout-sidebar .sb-sections {
119
- flex: 1;
120
- overflow-y: auto;
121
- overflow-x: hidden;
122
- padding: 4px 0;
123
- }
124
-
125
- /* ═══════════════════════ SidebarSection ═══════════════════════ */
126
- sidebar-section {
127
- display: flex;
128
- flex-wrap: wrap;
129
- align-items: center;
130
- position: relative;
131
-
132
- /* Hidden section in normal mode */
133
- &[data-hidden] {
134
- display: none;
135
- }
136
-
137
- /* Disabled section — shown but not interactive */
138
- &[data-disabled] {
139
- opacity: 0.35;
140
- pointer-events: none;
141
- filter: grayscale(0.5);
142
- }
143
-
144
- /* In edit mode, show disabled sections normally (admin might want to toggle visibility) */
145
- layout-sidebar[edit-mode] &[data-disabled] {
146
- opacity: 0.5;
147
- pointer-events: auto;
148
- filter: none;
149
- }
150
-
151
- /* In edit mode, hidden sections are dimmed */
152
- layout-sidebar[edit-mode] &[data-hidden] {
153
- display: flex;
154
- opacity: 0.35;
155
- }
156
-
157
- /* Drag states */
158
- &[data-dragging] {
159
- opacity: 0.4;
160
- }
161
-
162
- &[data-dragover] {
163
- border-top: 2px solid var(--sn-cat-server, #5cb8ff);
164
- }
165
- }
166
-
167
- /* Drag handle — edit mode only */
168
- sidebar-section .sec-drag-handle {
169
- display: none;
170
- align-items: center;
171
- padding: 0 2px;
172
- cursor: grab;
173
- color: var(--text-dim, var(--sn-text-dim, #888));
174
-
175
- &:active {
176
- cursor: grabbing;
177
- }
178
-
179
- & .material-symbols-outlined {
180
- font-size: 16px;
181
- }
182
-
183
- layout-sidebar[edit-mode] & {
184
- display: flex;
185
- }
186
-
187
- layout-sidebar[collapsed] & {
188
- display: none;
189
- }
190
- }
191
-
192
- /* Section row */
193
- sidebar-section .sec-item {
194
- display: flex;
195
- align-items: center;
196
- gap: 10px;
197
- flex: 1;
198
- padding: 6px 14px;
199
- min-height: 28px;
200
- cursor: pointer;
201
- color: var(--text-dim, var(--sn-text-dim, #888));
202
- transition: background 0.12s, color 0.12s;
203
- white-space: nowrap;
204
- overflow: hidden;
205
-
206
- layout-sidebar[edit-mode] & {
207
- padding-left: 4px;
208
- }
209
-
210
- &:hover {
211
- background: var(--bg-hover, var(--sn-node-hover, rgba(255, 255, 255, 0.06)));
212
- color: var(--text-main, var(--sn-text, #d4d4d4));
213
- }
214
- }
215
-
216
- sidebar-section .sec-icon {
217
- font-size: 16px;
218
- flex-shrink: 0;
219
- }
220
-
221
- sidebar-section .sec-label {
222
- font-size: 13px;
223
- font-weight: 500;
224
-
225
- layout-sidebar[collapsed] & {
226
- display: none;
227
- }
228
- }
229
-
230
- /* Expand chevron */
231
- sidebar-section .sec-expand {
232
- margin-left: auto;
233
- font-size: 16px;
234
- transition: transform 0.15s, opacity 0.15s;
235
-
236
- layout-sidebar[collapsed] & {
237
- display: none;
238
- }
239
-
240
- layout-sidebar[edit-mode] & {
241
- display: none;
242
- }
243
-
244
- /* Inactive state when no sub-panels */
245
- sidebar-section:not([data-has-sub]) & {
246
- opacity: 0.2;
247
- cursor: default;
248
- }
249
- }
250
-
251
- /* Active section */
252
- sidebar-section[data-active] > .sec-item {
253
- color: var(--text-main, var(--sn-text, #d4d4d4));
254
- background: var(--bg-hover, var(--sn-node-hover, rgba(255, 255, 255, 0.06)));
255
- border-left: 2px solid var(--sn-cat-server, #5cb8ff);
256
- padding-left: 12px;
257
-
258
- layout-sidebar[edit-mode] & {
259
- padding-left: 2px;
260
- }
261
- }
262
-
263
- /* Eye visibility button — edit mode only */
264
- sidebar-section .sec-eye {
265
- display: none;
266
- align-items: center;
267
- justify-content: center;
268
- padding: 4px 6px;
269
- background: transparent;
270
- border: none;
271
- border-radius: 4px;
272
- cursor: pointer;
273
- color: var(--text-dim, var(--sn-text-dim, #888));
274
- transition: color 0.15s, background 0.15s;
275
- flex-shrink: 0;
276
-
277
- &:hover {
278
- background: var(--bg-hover, var(--sn-node-hover, rgba(255, 255, 255, 0.06)));
279
- color: var(--text-main, var(--sn-text, #d4d4d4));
280
- }
281
-
282
- & .material-symbols-outlined {
283
- font-size: 16px;
284
- }
285
-
286
- layout-sidebar[edit-mode] & {
287
- display: flex;
288
- }
289
-
290
- layout-sidebar[collapsed] & {
291
- display: none;
292
- }
293
-
294
- sidebar-section[data-hidden] & {
295
- opacity: 0.5;
296
- }
297
- }
298
-
299
- /* ═══════════════════════ Sub-panels ═══════════════════════ */
300
- sidebar-section .sec-sub-panels {
301
- width: 100%;
302
- overflow: hidden;
303
- max-height: 0;
304
- transition: max-height 0.2s ease;
305
-
306
- layout-sidebar[collapsed] & {
307
- display: none;
308
- }
309
-
310
- layout-sidebar[edit-mode] & {
311
- display: none;
312
- }
313
- }
314
-
315
- sidebar-section[data-expanded] .sec-sub-panels {
316
- max-height: 300px;
317
- }
318
-
319
- sidebar-section[data-expanded] .sec-expand {
320
- transform: rotate(90deg);
321
- }
322
-
323
- sidebar-section .sub-panel-item {
324
- display: flex;
325
- align-items: center;
326
- gap: 8px;
327
- padding: 4px 14px 4px 38px;
328
- min-height: 24px;
329
- font-size: 12px;
330
- color: var(--text-dim, var(--sn-text-dim, #888));
331
- cursor: default;
332
- transition: background 0.12s, color 0.12s;
333
-
334
- &:hover {
335
- background: var(--bg-hover, var(--sn-node-hover, rgba(255, 255, 255, 0.04)));
336
- color: var(--text-main, var(--sn-text, #d4d4d4));
337
- }
338
-
339
- & .material-symbols-outlined {
340
- font-size: 14px;
341
- opacity: 0.6;
342
- }
343
- }
344
-
345
- /* Close button on sub-panel items */
346
- sidebar-section .sub-panel-close {
347
- display: flex;
348
- align-items: center;
349
- justify-content: center;
350
- margin-left: auto;
351
- padding: 2px;
352
- background: transparent;
353
- border: none;
354
- border-radius: 3px;
355
- cursor: pointer;
356
- color: var(--text-dim, var(--sn-text-dim, #888));
357
- opacity: 0;
358
- transition: opacity 0.12s, background 0.12s, color 0.12s;
359
-
360
- & .material-symbols-outlined {
361
- font-size: 14px;
362
- }
363
-
364
- &:hover {
365
- background: color-mix(in srgb, var(--sn-danger-color, #ef4444) 15%, transparent);
366
- color: var(--sn-danger-color, #ff6b6b);
367
- }
368
- }
369
-
370
- /* Show close only on hover of non-master items */
371
- sidebar-section .sub-panel-item:hover .sub-panel-close {
372
- opacity: 1;
373
- }
374
-
375
- /* Hide close button on master panel items */
376
- sidebar-sub-item[data-master] .sub-panel-close {
377
- display: none;
378
- }
379
- `;
@@ -1,263 +0,0 @@
1
- /**
2
- * LayoutSidebar — collapsible workspace navigation with edit mode
3
- *
4
- * Normal mode: shows only visible sections
5
- * Edit mode (Blender-style): shows all sections with eye toggles + drag handles
6
- *
7
- * @module symbiote-node/layout/LayoutSidebar
8
- */
9
- import Symbiote from '@symbiotejs/symbiote';
10
- import { sidebarTemplate } from './LayoutSidebar.tpl.js';
11
- import { sidebarStyles } from './LayoutSidebar.css.js';
12
- import { navigate } from '../LayoutRouter/LayoutRouter.js';
13
- import './SidebarSection.js';
14
-
15
- const STORAGE_KEY_COLLAPSED = 'sn-sidebar-collapsed';
16
- const STORAGE_KEY_CONFIG = 'sn-sidebar-config';
17
- const STORAGE_KEY_WIDTH = 'sn-sidebar-width';
18
-
19
- export class LayoutSidebar extends Symbiote {
20
- static isoMode = true;
21
-
22
- init$ = {
23
- collapsed: false,
24
- editMode: false,
25
- sections: [],
26
-
27
- onToggle: () => {
28
- this.$.collapsed = !this.$.collapsed;
29
- },
30
-
31
- onToggleEditMode: () => {
32
- this.$.editMode = !this.$.editMode;
33
- },
34
- };
35
-
36
- /** @type {Array<{id: string, icon: string, label: string}>} */
37
- #allSections = [];
38
-
39
- renderCallback() {
40
- // Reflect attributes
41
- this.sub('collapsed', (val) => {
42
- this.toggleAttribute('collapsed', val);
43
- });
44
- this.sub('editMode', (val) => {
45
- this.toggleAttribute('edit-mode', val);
46
- });
47
-
48
- // Restore collapsed state (default: collapsed)
49
- if (typeof localStorage !== 'undefined') {
50
- const stored = localStorage.getItem(STORAGE_KEY_COLLAPSED);
51
- if (stored === null || stored === 'true') {
52
- this.$.collapsed = true;
53
- }
54
-
55
- // Restore saved width
56
- const savedWidth = localStorage.getItem(STORAGE_KEY_WIDTH);
57
- if (savedWidth) this.style.width = savedWidth + 'px';
58
- }
59
-
60
- // Persist collapsed state
61
- this.sub('collapsed', (val) => {
62
- if (typeof localStorage !== 'undefined') {
63
- localStorage.setItem(STORAGE_KEY_COLLAPSED, String(val));
64
- // Reset inline width when collapsing (CSS handles 48px)
65
- if (val) {
66
- this.style.width = '';
67
- this.style.minWidth = '';
68
- } else {
69
- // Restore saved width when expanding
70
- const w = localStorage.getItem(STORAGE_KEY_WIDTH);
71
- if (w) {
72
- this.style.width = w + 'px';
73
- this.style.minWidth = w + 'px';
74
- }
75
- }
76
- }
77
- });
78
-
79
- // Resize drag handle
80
- const handle = this.querySelector('.sb-resize-handle');
81
- if (handle) {
82
- let startX = 0;
83
- let startW = 0;
84
-
85
- const onMove = (e) => {
86
- const newWidth = Math.max(120, Math.min(600, startW + (e.clientX - startX)));
87
- this.style.width = newWidth + 'px';
88
- this.style.minWidth = newWidth + 'px';
89
- this.style.transition = 'none';
90
- };
91
-
92
- const onUp = () => {
93
- handle.classList.remove('dragging');
94
- this.style.transition = '';
95
- const w = this.offsetWidth;
96
- if (typeof localStorage !== 'undefined') {
97
- localStorage.setItem(STORAGE_KEY_WIDTH, w);
98
- }
99
- if (typeof document !== 'undefined') {
100
- document.removeEventListener('pointermove', onMove);
101
- document.removeEventListener('pointerup', onUp);
102
- }
103
- };
104
-
105
- handle.addEventListener('pointerdown', (e) => {
106
- e.preventDefault();
107
- e.stopPropagation();
108
- startX = e.clientX;
109
- startW = this.offsetWidth;
110
- handle.classList.add('dragging');
111
- if (typeof document !== 'undefined') {
112
- document.addEventListener('pointermove', onMove);
113
- document.addEventListener('pointerup', onUp);
114
- }
115
- });
116
- }
117
- }
118
-
119
- /**
120
- * Configure sidebar sections
121
- * @param {Array<{id: string, icon: string, label: string}>} items
122
- */
123
- setSections(items) {
124
- this.#allSections = items;
125
-
126
- // Load saved config (order + visibility)
127
- const savedConfig = this.#loadConfig();
128
- let ordered = items;
129
-
130
- if (savedConfig) {
131
- // Reorder based on saved order
132
- const orderMap = new Map(savedConfig.map((c, i) => [c.id, i]));
133
- ordered = [...items].sort((a, b) => {
134
- const ai = orderMap.get(a.id) ?? 999;
135
- const bi = orderMap.get(b.id) ?? 999;
136
- return ai - bi;
137
- });
138
- }
139
-
140
- this.#buildSections(ordered, savedConfig);
141
-
142
- // Subscribe to route changes to update active section
143
- this.sub('ROUTER/panel', (panel) => {
144
- this.$.sections = this.$.sections.map((s) => ({
145
- ...s,
146
- isActive: s.sectionId === panel,
147
- }));
148
- });
149
- }
150
-
151
- /**
152
- * Build sections array from ordered items + config
153
- * @param {Array<{id: string, icon: string, label: string}>} items
154
- * @param {Array<{id: string, visible: boolean}>|null} config
155
- */
156
- #buildSections(items, config) {
157
- const visibilityMap = config
158
- ? new Map(config.map((c) => [c.id, c.visible]))
159
- : null;
160
-
161
- this.$.sections = items.map((item) => ({
162
- sectionId: item.id,
163
- icon: item.icon,
164
- label: item.label,
165
- isActive: false,
166
- isVisible: visibilityMap ? (visibilityMap.get(item.id) ?? true) : true,
167
- isExpanded: false,
168
- subPanels: [],
169
- }));
170
- }
171
-
172
- /**
173
- * Toggle visibility of a section
174
- * @param {string} sectionId
175
- */
176
- toggleVisibility(sectionId) {
177
- this.$.sections = this.$.sections.map((s) => {
178
- if (s.sectionId !== sectionId) return s;
179
- return { ...s, isVisible: !s.isVisible };
180
- });
181
- this.#saveConfig();
182
- }
183
-
184
- /**
185
- * Move section by drag (swap positions)
186
- * @param {number} fromIndex
187
- * @param {number} toIndex
188
- */
189
- moveSection(fromIndex, toIndex) {
190
- const arr = [...this.$.sections];
191
- const [moved] = arr.splice(fromIndex, 1);
192
- arr.splice(toIndex, 0, moved);
193
- this.$.sections = arr;
194
- this.#saveConfig();
195
- }
196
-
197
- /**
198
- * Reset sections to default order and visibility
199
- */
200
- resetConfig() {
201
- if (typeof localStorage !== 'undefined') {
202
- localStorage.removeItem(STORAGE_KEY_CONFIG);
203
- }
204
- this.#buildSections(this.#allSections, null);
205
- }
206
-
207
- /**
208
- * Save current section order and visibility
209
- */
210
- #saveConfig() {
211
- const config = this.$.sections.map((s) => ({
212
- id: s.sectionId,
213
- visible: s.isVisible,
214
- }));
215
- if (typeof localStorage !== 'undefined') {
216
- localStorage.setItem(STORAGE_KEY_CONFIG, JSON.stringify(config));
217
- }
218
- }
219
-
220
- /**
221
- * Load saved section config
222
- * @returns {Array<{id: string, visible: boolean}>|null}
223
- */
224
- #loadConfig() {
225
- try {
226
- if (typeof localStorage !== 'undefined') {
227
- const raw = localStorage.getItem(STORAGE_KEY_CONFIG);
228
- return raw ? JSON.parse(raw) : null;
229
- }
230
- } catch {
231
- return null;
232
- }
233
- return null;
234
- }
235
-
236
- /**
237
- * Update sub-panel list for a section
238
- * @param {string} sectionId
239
- * @param {Array<{title: string, icon: string}>} panels
240
- */
241
- updateSubPanels(sectionId, panels) {
242
- this.$.sections = this.$.sections.map((s) => {
243
- if (s.sectionId !== sectionId) return s;
244
- return { ...s, subPanels: panels };
245
- });
246
- }
247
-
248
- /**
249
- * Mark sections as disabled (shown but not clickable)
250
- * @param {string[]} disabledIds - Section IDs to disable
251
- */
252
- setDisabledSections(disabledIds) {
253
- const disabledSet = new Set(disabledIds);
254
- this.$.sections = this.$.sections.map((s) => ({
255
- ...s,
256
- isDisabled: disabledSet.has(s.sectionId),
257
- }));
258
- }
259
- }
260
-
261
- LayoutSidebar.template = sidebarTemplate;
262
- LayoutSidebar.rootStyles = sidebarStyles;
263
- LayoutSidebar.reg('layout-sidebar');
@@ -1,20 +0,0 @@
1
- /**
2
- * LayoutSidebar template
3
- * @module symbiote-node/layout/LayoutSidebar
4
- */
5
- import { html } from '@symbiotejs/symbiote';
6
-
7
- export const sidebarTemplate = html`
8
- <div class="sb-header">
9
- <button class="sb-header-btn" ${{ onclick: 'onToggleEditMode' }}>
10
- <span class="material-symbols-outlined">tune</span>
11
- </button>
12
- <div class="sb-header-spacer"></div>
13
- <button class="sb-header-btn" ${{ onclick: 'onToggle' }}>
14
- <span class="material-symbols-outlined sb-collapse-icon">chevron_left</span>
15
- </button>
16
- </div>
17
-
18
- <div class="sb-sections" itemize="sections" item-tag="sidebar-section"></div>
19
- <div class="sb-resize-handle"></div>
20
- `;