project-graph-mcp 2.2.6 → 2.3.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 (150) hide show
  1. package/ARCHITECTURE.md +81 -0
  2. package/CHANGELOG.md +57 -0
  3. package/README.md +9 -4
  4. package/package.json +6 -13
  5. package/src/compact/expand.js +1 -1
  6. package/src/core/graph-builder.js +2 -2
  7. package/src/core/parser.js +2 -2
  8. package/src/network/server.js +1 -2
  9. package/vendor/symbiote-node/CHANGELOG.md +31 -0
  10. package/vendor/symbiote-node/LICENSE +21 -0
  11. package/vendor/symbiote-node/README.md +206 -0
  12. package/vendor/symbiote-node/canvas/AutoLayout.js +725 -0
  13. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.css.js +73 -0
  14. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.js +93 -0
  15. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.tpl.js +9 -0
  16. package/vendor/symbiote-node/canvas/CanvasConnectionRenderer.js +962 -0
  17. package/vendor/symbiote-node/canvas/ConnectionRenderer.js +1468 -0
  18. package/vendor/symbiote-node/canvas/FlowSimulator.js +323 -0
  19. package/vendor/symbiote-node/canvas/ForceLayout.js +189 -0
  20. package/vendor/symbiote-node/canvas/ForceWorker.js +1325 -0
  21. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.css.js +97 -0
  22. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.js +176 -0
  23. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.tpl.js +12 -0
  24. package/vendor/symbiote-node/canvas/LODManager.js +88 -0
  25. package/vendor/symbiote-node/canvas/Minimap/Minimap.css.js +71 -0
  26. package/vendor/symbiote-node/canvas/Minimap/Minimap.js +207 -0
  27. package/vendor/symbiote-node/canvas/Minimap/Minimap.tpl.js +9 -0
  28. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.css.js +261 -0
  29. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.js +1840 -0
  30. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.tpl.js +22 -0
  31. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.css.js +97 -0
  32. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.js +132 -0
  33. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.tpl.js +21 -0
  34. package/vendor/symbiote-node/canvas/NodeViewManager.js +584 -0
  35. package/vendor/symbiote-node/canvas/PinExpansion.js +131 -0
  36. package/vendor/symbiote-node/canvas/PseudoConnection.js +80 -0
  37. package/vendor/symbiote-node/canvas/SubgraphManager.js +201 -0
  38. package/vendor/symbiote-node/canvas/SubgraphRouter.js +443 -0
  39. package/vendor/symbiote-node/canvas/ViewportActions.js +446 -0
  40. package/vendor/symbiote-node/core/Connection.js +45 -0
  41. package/vendor/symbiote-node/core/Editor.js +451 -0
  42. package/vendor/symbiote-node/core/Frame.js +31 -0
  43. package/vendor/symbiote-node/core/GraphMermaid.js +348 -0
  44. package/vendor/symbiote-node/core/GraphText.js +210 -0
  45. package/vendor/symbiote-node/core/Node.js +143 -0
  46. package/vendor/symbiote-node/core/Portal.js +104 -0
  47. package/vendor/symbiote-node/core/Socket.js +185 -0
  48. package/vendor/symbiote-node/core/SubgraphNode.js +125 -0
  49. package/vendor/symbiote-node/index.js +103 -0
  50. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.css.js +361 -0
  51. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.js +332 -0
  52. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.tpl.js +96 -0
  53. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.css.js +104 -0
  54. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.js +133 -0
  55. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.tpl.js +33 -0
  56. package/vendor/symbiote-node/interactions/ConnectFlow.js +307 -0
  57. package/vendor/symbiote-node/interactions/Drag.js +102 -0
  58. package/vendor/symbiote-node/interactions/Selector.js +132 -0
  59. package/vendor/symbiote-node/interactions/SnapGrid.js +65 -0
  60. package/vendor/symbiote-node/interactions/Zoom.js +140 -0
  61. package/vendor/symbiote-node/layout/ActionZone/ActionZone.css.js +88 -0
  62. package/vendor/symbiote-node/layout/ActionZone/ActionZone.js +254 -0
  63. package/vendor/symbiote-node/layout/ActionZone/ActionZone.tpl.js +11 -0
  64. package/vendor/symbiote-node/layout/Layout/Layout.css.js +88 -0
  65. package/vendor/symbiote-node/layout/Layout/Layout.js +622 -0
  66. package/vendor/symbiote-node/layout/Layout/Layout.tpl.js +25 -0
  67. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.css.js +293 -0
  68. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.js +467 -0
  69. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.tpl.js +33 -0
  70. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.css.js +46 -0
  71. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.js +102 -0
  72. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.tpl.js +6 -0
  73. package/vendor/symbiote-node/layout/LayoutRouter/LayoutRouter.js +156 -0
  74. package/vendor/symbiote-node/layout/LayoutRouter/routerSync.js +250 -0
  75. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.css.js +379 -0
  76. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.js +263 -0
  77. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.tpl.js +20 -0
  78. package/vendor/symbiote-node/layout/LayoutSidebar/SidebarSection.js +183 -0
  79. package/vendor/symbiote-node/layout/LayoutTree.js +246 -0
  80. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.css.js +43 -0
  81. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.js +89 -0
  82. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.tpl.js +14 -0
  83. package/vendor/symbiote-node/layout/index.js +16 -0
  84. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.css.js +61 -0
  85. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.js +79 -0
  86. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.tpl.js +19 -0
  87. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.css.js +41 -0
  88. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.js +24 -0
  89. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.tpl.js +16 -0
  90. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.css.js +65 -0
  91. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.js +29 -0
  92. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.tpl.js +13 -0
  93. package/vendor/symbiote-node/node/GraphNode/GraphNode.css.js +683 -0
  94. package/vendor/symbiote-node/node/GraphNode/GraphNode.js +92 -0
  95. package/vendor/symbiote-node/node/GraphNode/GraphNode.tpl.js +17 -0
  96. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.js +25 -0
  97. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.tpl.js +7 -0
  98. package/vendor/symbiote-node/node/PortItem/PortItem.css.js +90 -0
  99. package/vendor/symbiote-node/node/PortItem/PortItem.js +87 -0
  100. package/vendor/symbiote-node/node/PortItem/PortItem.tpl.js +10 -0
  101. package/vendor/symbiote-node/package.json +59 -0
  102. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.css.js +143 -0
  103. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.js +131 -0
  104. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.tpl.js +16 -0
  105. package/vendor/symbiote-node/plugins/History.js +384 -0
  106. package/vendor/symbiote-node/plugins/Readonly.js +59 -0
  107. package/vendor/symbiote-node/shapes/CircleShape.js +80 -0
  108. package/vendor/symbiote-node/shapes/CommentShape.js +35 -0
  109. package/vendor/symbiote-node/shapes/DiamondShape.js +115 -0
  110. package/vendor/symbiote-node/shapes/NodeShape.js +80 -0
  111. package/vendor/symbiote-node/shapes/PillShape.js +91 -0
  112. package/vendor/symbiote-node/shapes/RectShape.js +72 -0
  113. package/vendor/symbiote-node/shapes/SVGShape.js +494 -0
  114. package/vendor/symbiote-node/shapes/index.js +53 -0
  115. package/vendor/symbiote-node/themes/Palette.js +32 -0
  116. package/vendor/symbiote-node/themes/Skin.js +113 -0
  117. package/vendor/symbiote-node/themes/Theme.js +84 -0
  118. package/vendor/symbiote-node/themes/carbon.js +137 -0
  119. package/vendor/symbiote-node/themes/dark.js +137 -0
  120. package/vendor/symbiote-node/themes/ebook.js +138 -0
  121. package/vendor/symbiote-node/themes/grey.js +137 -0
  122. package/vendor/symbiote-node/themes/light.js +137 -0
  123. package/vendor/symbiote-node/themes/neon.js +138 -0
  124. package/vendor/symbiote-node/themes/pcb.js +273 -0
  125. package/vendor/symbiote-node/themes/synthwave.js +137 -0
  126. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.css.js +86 -0
  127. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.js +128 -0
  128. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.tpl.js +29 -0
  129. package/web/app.js +6 -5
  130. package/web/components/canvas-graph.js +1666 -0
  131. package/web/components/event-feed/CodeWidget.js +32 -0
  132. package/web/components/event-feed/EventWidget.js +97 -0
  133. package/web/components/event-feed/ListWidget.js +57 -0
  134. package/web/components/event-feed/MiniGraphWidget.js +69 -0
  135. package/web/dashboard.js +1 -1
  136. package/web/index.html +4 -0
  137. package/web/panels/ActionBoard/ActionBoard.js +1 -1
  138. package/web/panels/SettingsPanel/SettingsPanel.tpl.js +1 -1
  139. package/web/panels/code-viewer.js +50 -15
  140. package/web/panels/dep-graph.js +2712 -7
  141. package/web/panels/file-tree.js +5 -2
  142. package/web/panels/live-monitor.js +75 -3
  143. package/web/style.css +33 -0
  144. package/docs/img/explorer-compact.jpg +0 -0
  145. package/docs/img/explorer-expanded.jpg +0 -0
  146. package/src/.contextignore +0 -22
  147. package/src/.project-graph-cache.json +0 -1
  148. package/src/compact/.project-graph-cache.json +0 -1
  149. package/web/.project-graph-cache.json +0 -1
  150. package/web/panels/SettingsPanel/.project-graph-cache.json +0 -1
@@ -0,0 +1,79 @@
1
+ /**
2
+ * ContextMenu — right-click menu for graph editor
3
+ *
4
+ * Shows contextual actions for canvas, nodes, and connections.
5
+ * Triple-file component: .js + .tpl.js + .css.js
6
+ *
7
+ * @module symbiote-node/components/ContextMenu
8
+ */
9
+
10
+ import Symbiote, { html } from '@symbiotejs/symbiote';
11
+ import { template, ctxItemTemplate } from './ContextMenu.tpl.js';
12
+ import { styles } from './ContextMenu.css.js';
13
+
14
+ class CtxItem extends Symbiote {
15
+ init$ = {
16
+ label: '',
17
+ icon: '',
18
+ onclick: () => {
19
+ this.$['^onItemClick'](this.$.label);
20
+ },
21
+ };
22
+ }
23
+
24
+ CtxItem.template = ctxItemTemplate;
25
+ CtxItem.reg('ctx-item');
26
+
27
+ export class ContextMenu extends Symbiote {
28
+
29
+ /** @type {Map<string, function>} */
30
+ _actions = new Map();
31
+
32
+ init$ = {
33
+ items: [],
34
+ visible: false,
35
+ onBackdropClick: () => this.hide(),
36
+ onItemClick: (label) => {
37
+ const action = this._actions.get(label);
38
+ if (action) action();
39
+ this.hide();
40
+ },
41
+ };
42
+
43
+ /**
44
+ * Show the menu at screen coordinates
45
+ * @param {number} x - Screen X
46
+ * @param {number} y - Screen Y
47
+ * @param {Array<{label: string, icon: string, action: function}>} items
48
+ */
49
+ show(x, y, items) {
50
+ this._actions.clear();
51
+ for (const item of items) {
52
+ this._actions.set(item.label, item.action);
53
+ }
54
+ this.$.items = items.map((i) => ({ label: i.label, icon: i.icon }));
55
+ const menu = this.querySelector('.sn-ctx-menu');
56
+ if (menu) {
57
+ menu.style.left = `${x}px`;
58
+ menu.style.top = `${y}px`;
59
+ }
60
+ this.$.visible = true;
61
+ }
62
+
63
+ /** Hide menu */
64
+ hide() {
65
+ this.$.visible = false;
66
+ this.$.items = [];
67
+ this._actions.clear();
68
+ }
69
+
70
+ renderCallback() {
71
+ this.sub('visible', (val) => {
72
+ this.toggleAttribute('hidden', !val);
73
+ });
74
+ }
75
+ }
76
+
77
+ ContextMenu.template = template;
78
+ ContextMenu.rootStyles = styles;
79
+ ContextMenu.reg('context-menu');
@@ -0,0 +1,19 @@
1
+ /**
2
+ * ContextMenu template
3
+ * @module symbiote-node/menu/ContextMenu.tpl
4
+ */
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export const template = html`
8
+ <div class="sn-ctx-backdrop" ${{ onclick: 'onBackdropClick' }}></div>
9
+ <div class="sn-ctx-menu">
10
+ <div class="ctx-items" ${{ itemize: 'items', 'item-tag': 'ctx-item' }}></div>
11
+ </div>
12
+ `;
13
+
14
+ export const ctxItemTemplate = html`
15
+ <button class="sn-ctx-btn" ${{ onclick: 'onclick' }}>
16
+ <span class="material-symbols-outlined sn-ctx-icon">{{icon}}</span>
17
+ <span>{{label}}</span>
18
+ </button>
19
+ `;
@@ -0,0 +1,41 @@
1
+ /**
2
+ * CtrlItem styles
3
+ * @module symbiote-node/node/CtrlItem.css
4
+ */
5
+ import { css } from '@symbiotejs/symbiote';
6
+
7
+ export const styles = css`
8
+ ctrl-item {
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: 2px;
12
+ padding: 4px 12px;
13
+
14
+ & .sn-ctrl-label {
15
+ font-size: 10px;
16
+ text-transform: uppercase;
17
+ color: var(--sn-text-dim, #94a3b8);
18
+ letter-spacing: 0.5px;
19
+ }
20
+
21
+ & .sn-ctrl-input {
22
+ background: rgba(0, 0, 0, 0.3);
23
+ border: 1px solid color-mix(in srgb, currentColor 10%, transparent);
24
+ border-radius: 4px;
25
+ padding: 4px 8px;
26
+ color: var(--sn-text, #e2e8f0);
27
+ font-size: 12px;
28
+ outline: none;
29
+ font-family: inherit;
30
+
31
+ &:focus {
32
+ border-color: var(--sn-node-accent, #4a9eff);
33
+ }
34
+
35
+ &[readonly] {
36
+ opacity: 0.6;
37
+ cursor: default;
38
+ }
39
+ }
40
+ }
41
+ `;
@@ -0,0 +1,24 @@
1
+ /**
2
+ * CtrlItem — itemize item for node embedded controls
3
+ *
4
+ * Rendered by GraphNode via itemize API.
5
+ * Receives {key, label, inputType, value, isReadonly} from parent data.
6
+ *
7
+ * @module symbiote-node/components/CtrlItem
8
+ */
9
+
10
+ import Symbiote from '@symbiotejs/symbiote';
11
+ import { template } from './CtrlItem.tpl.js';
12
+ import { styles } from './CtrlItem.css.js';
13
+
14
+ export class CtrlItem extends Symbiote {
15
+ key = '';
16
+ label = '';
17
+ inputType = 'text';
18
+ value = '';
19
+ isReadonly = false;
20
+ }
21
+
22
+ CtrlItem.template = template;
23
+ CtrlItem.rootStyles = styles;
24
+ CtrlItem.reg('ctrl-item');
@@ -0,0 +1,16 @@
1
+ /**
2
+ * CtrlItem template
3
+ * @module symbiote-node/node/CtrlItem.tpl
4
+ */
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export const template = html`
8
+ <label class="sn-ctrl-label">{{label}}</label>
9
+ <input class="sn-ctrl-input"
10
+ ${{
11
+ '@type': 'inputType',
12
+ '@value': 'value',
13
+ '@readonly': 'isReadonly',
14
+ }}
15
+ >
16
+ `;
@@ -0,0 +1,65 @@
1
+ /**
2
+ * GraphFrame styles
3
+ * @module symbiote-node/node/GraphFrame.css
4
+ */
5
+ import { css } from '@symbiotejs/symbiote';
6
+
7
+ export const styles = css`
8
+ graph-frame {
9
+ position: absolute;
10
+ display: block;
11
+ border: var(--sn-frame-border-width, 2px) var(--sn-frame-border-style, solid) color-mix(in srgb, var(--frame-color, #4a9eff) 60%, transparent);
12
+ border-radius: var(--sn-frame-radius, 12px);
13
+ background: color-mix(in srgb, var(--frame-color, #4a9eff) 8%, transparent);
14
+ z-index: -1;
15
+ pointer-events: all;
16
+ min-width: 120px;
17
+ min-height: 80px;
18
+
19
+ & .sn-frame-header {
20
+ display: flex;
21
+ align-items: center;
22
+ gap: 6px;
23
+ padding: 6px 12px;
24
+ font-family: var(--sn-frame-font, var(--sn-font, 'Inter', sans-serif));
25
+ font-size: var(--sn-frame-font-size, 13px);
26
+ font-weight: 600;
27
+ color: color-mix(in srgb, var(--frame-color, #4a9eff) 90%, white);
28
+ user-select: none;
29
+ cursor: grab;
30
+ border-bottom: 1px solid color-mix(in srgb, var(--frame-color, #4a9eff) 20%, transparent);
31
+ }
32
+
33
+ & .sn-frame-icon {
34
+ font-size: 16px;
35
+ opacity: 0.7;
36
+ }
37
+
38
+ & .sn-frame-label {
39
+ white-space: nowrap;
40
+ overflow: hidden;
41
+ text-overflow: ellipsis;
42
+ }
43
+
44
+ & .sn-frame-resize {
45
+ position: absolute;
46
+ bottom: 0;
47
+ right: 0;
48
+ width: 16px;
49
+ height: 16px;
50
+ cursor: nwse-resize;
51
+ border-right: 3px solid color-mix(in srgb, var(--frame-color, #4a9eff) 40%, transparent);
52
+ border-bottom: 3px solid color-mix(in srgb, var(--frame-color, #4a9eff) 40%, transparent);
53
+ border-radius: 0 0 10px 0;
54
+ }
55
+
56
+ &:hover {
57
+ border-color: color-mix(in srgb, var(--frame-color, #4a9eff) 80%, transparent);
58
+ }
59
+
60
+ &[data-selected] {
61
+ border-color: var(--frame-color, #4a9eff);
62
+ box-shadow: 0 0 12px color-mix(in srgb, var(--frame-color, #4a9eff) 30%, transparent);
63
+ }
64
+ }
65
+ `;
@@ -0,0 +1,29 @@
1
+ /**
2
+ * GraphFrame — visual grouping frame component (Blender-style)
3
+ *
4
+ * Colored rectangle with label that groups nodes spatially.
5
+ * Moving the frame moves all nodes whose positions fall within its bounds.
6
+ *
7
+ * @module symbiote-node/components/GraphFrame
8
+ */
9
+
10
+ import Symbiote from '@symbiotejs/symbiote';
11
+ import { template } from './GraphFrame.tpl.js';
12
+ import { styles } from './GraphFrame.css.js';
13
+
14
+ export class GraphFrame extends Symbiote {
15
+ init$ = {
16
+ label: 'Group',
17
+ color: '#4a9eff',
18
+ };
19
+
20
+ renderCallback() {
21
+ this.sub('color', (val) => {
22
+ if (val) this.style.setProperty('--frame-color', val);
23
+ });
24
+ }
25
+ }
26
+
27
+ GraphFrame.template = template;
28
+ GraphFrame.rootStyles = styles;
29
+ GraphFrame.reg('graph-frame');
@@ -0,0 +1,13 @@
1
+ /**
2
+ * GraphFrame template
3
+ * @module symbiote-node/node/GraphFrame.tpl
4
+ */
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export const template = html`
8
+ <div class="sn-frame-header">
9
+ <span class="material-symbols-outlined sn-frame-icon">dashboard</span>
10
+ <span class="sn-frame-label">{{label}}</span>
11
+ </div>
12
+ <div ref="resizeHandle" class="sn-frame-resize"></div>
13
+ `;