project-graph-mcp 2.2.6 → 2.3.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 (155) hide show
  1. package/ARCHITECTURE.md +81 -0
  2. package/CHANGELOG.md +57 -0
  3. package/README.md +9 -4
  4. package/package.json +4 -13
  5. package/project-graph-mcp-2.3.0.tgz +0 -0
  6. package/src/compact/expand.js +1 -1
  7. package/src/core/graph-builder.js +2 -2
  8. package/src/core/parser.js +2 -2
  9. package/src/network/server.js +1 -2
  10. package/src/network/web-server.js +1 -1
  11. package/vendor/symbiote-node/CHANGELOG.md +31 -0
  12. package/vendor/symbiote-node/LICENSE +21 -0
  13. package/vendor/symbiote-node/README.md +206 -0
  14. package/vendor/symbiote-node/canvas/AutoLayout.js +725 -0
  15. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.css.js +73 -0
  16. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.js +93 -0
  17. package/vendor/symbiote-node/canvas/Breadcrumb/Breadcrumb.tpl.js +9 -0
  18. package/vendor/symbiote-node/canvas/CanvasConnectionRenderer.js +962 -0
  19. package/vendor/symbiote-node/canvas/ConnectionRenderer.js +1468 -0
  20. package/vendor/symbiote-node/canvas/FlowSimulator.js +323 -0
  21. package/vendor/symbiote-node/canvas/ForceLayout.js +189 -0
  22. package/vendor/symbiote-node/canvas/ForceWorker.js +1325 -0
  23. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.css.js +97 -0
  24. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.js +176 -0
  25. package/vendor/symbiote-node/canvas/GraphTabs/GraphTabs.tpl.js +12 -0
  26. package/vendor/symbiote-node/canvas/LODManager.js +88 -0
  27. package/vendor/symbiote-node/canvas/Minimap/Minimap.css.js +71 -0
  28. package/vendor/symbiote-node/canvas/Minimap/Minimap.js +207 -0
  29. package/vendor/symbiote-node/canvas/Minimap/Minimap.tpl.js +9 -0
  30. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.css.js +261 -0
  31. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.js +1840 -0
  32. package/vendor/symbiote-node/canvas/NodeCanvas/NodeCanvas.tpl.js +22 -0
  33. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.css.js +97 -0
  34. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.js +132 -0
  35. package/vendor/symbiote-node/canvas/NodeSearch/NodeSearch.tpl.js +21 -0
  36. package/vendor/symbiote-node/canvas/NodeViewManager.js +584 -0
  37. package/vendor/symbiote-node/canvas/PinExpansion.js +131 -0
  38. package/vendor/symbiote-node/canvas/PseudoConnection.js +80 -0
  39. package/vendor/symbiote-node/canvas/SubgraphManager.js +201 -0
  40. package/vendor/symbiote-node/canvas/SubgraphRouter.js +443 -0
  41. package/vendor/symbiote-node/canvas/ViewportActions.js +446 -0
  42. package/vendor/symbiote-node/core/Connection.js +45 -0
  43. package/vendor/symbiote-node/core/Editor.js +451 -0
  44. package/vendor/symbiote-node/core/Frame.js +31 -0
  45. package/vendor/symbiote-node/core/GraphMermaid.js +348 -0
  46. package/vendor/symbiote-node/core/GraphText.js +210 -0
  47. package/vendor/symbiote-node/core/Node.js +143 -0
  48. package/vendor/symbiote-node/core/Portal.js +104 -0
  49. package/vendor/symbiote-node/core/Socket.js +185 -0
  50. package/vendor/symbiote-node/core/SubgraphNode.js +125 -0
  51. package/vendor/symbiote-node/index.js +103 -0
  52. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.css.js +361 -0
  53. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.js +332 -0
  54. package/vendor/symbiote-node/inspector/InspectorPanel/InspectorPanel.tpl.js +96 -0
  55. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.css.js +104 -0
  56. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.js +133 -0
  57. package/vendor/symbiote-node/inspector/TemplatePreview/TemplatePreview.tpl.js +33 -0
  58. package/vendor/symbiote-node/interactions/ConnectFlow.js +307 -0
  59. package/vendor/symbiote-node/interactions/Drag.js +102 -0
  60. package/vendor/symbiote-node/interactions/Selector.js +132 -0
  61. package/vendor/symbiote-node/interactions/SnapGrid.js +65 -0
  62. package/vendor/symbiote-node/interactions/Zoom.js +140 -0
  63. package/vendor/symbiote-node/layout/ActionZone/ActionZone.css.js +88 -0
  64. package/vendor/symbiote-node/layout/ActionZone/ActionZone.js +254 -0
  65. package/vendor/symbiote-node/layout/ActionZone/ActionZone.tpl.js +11 -0
  66. package/vendor/symbiote-node/layout/Layout/Layout.css.js +88 -0
  67. package/vendor/symbiote-node/layout/Layout/Layout.js +622 -0
  68. package/vendor/symbiote-node/layout/Layout/Layout.tpl.js +25 -0
  69. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.css.js +293 -0
  70. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.js +467 -0
  71. package/vendor/symbiote-node/layout/LayoutNode/LayoutNode.tpl.js +33 -0
  72. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.css.js +46 -0
  73. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.js +102 -0
  74. package/vendor/symbiote-node/layout/LayoutPreview/LayoutPreview.tpl.js +6 -0
  75. package/vendor/symbiote-node/layout/LayoutRouter/LayoutRouter.js +156 -0
  76. package/vendor/symbiote-node/layout/LayoutRouter/routerSync.js +250 -0
  77. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.css.js +379 -0
  78. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.js +263 -0
  79. package/vendor/symbiote-node/layout/LayoutSidebar/LayoutSidebar.tpl.js +20 -0
  80. package/vendor/symbiote-node/layout/LayoutSidebar/SidebarSection.js +183 -0
  81. package/vendor/symbiote-node/layout/LayoutTree.js +246 -0
  82. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.css.js +43 -0
  83. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.js +89 -0
  84. package/vendor/symbiote-node/layout/PanelMenu/PanelMenu.tpl.js +14 -0
  85. package/vendor/symbiote-node/layout/index.js +16 -0
  86. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.css.js +61 -0
  87. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.js +79 -0
  88. package/vendor/symbiote-node/menu/ContextMenu/ContextMenu.tpl.js +19 -0
  89. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.css.js +41 -0
  90. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.js +24 -0
  91. package/vendor/symbiote-node/node/CtrlItem/CtrlItem.tpl.js +16 -0
  92. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.css.js +65 -0
  93. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.js +29 -0
  94. package/vendor/symbiote-node/node/GraphFrame/GraphFrame.tpl.js +13 -0
  95. package/vendor/symbiote-node/node/GraphNode/GraphNode.css.js +683 -0
  96. package/vendor/symbiote-node/node/GraphNode/GraphNode.js +92 -0
  97. package/vendor/symbiote-node/node/GraphNode/GraphNode.tpl.js +17 -0
  98. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.js +25 -0
  99. package/vendor/symbiote-node/node/NodeSocket/NodeSocket.tpl.js +7 -0
  100. package/vendor/symbiote-node/node/PortItem/PortItem.css.js +90 -0
  101. package/vendor/symbiote-node/node/PortItem/PortItem.js +87 -0
  102. package/vendor/symbiote-node/node/PortItem/PortItem.tpl.js +10 -0
  103. package/vendor/symbiote-node/package.json +59 -0
  104. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.css.js +143 -0
  105. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.js +131 -0
  106. package/vendor/symbiote-node/palette/PaletteBrowser/PaletteBrowser.tpl.js +16 -0
  107. package/vendor/symbiote-node/plugins/History.js +384 -0
  108. package/vendor/symbiote-node/plugins/Readonly.js +59 -0
  109. package/vendor/symbiote-node/shapes/CircleShape.js +80 -0
  110. package/vendor/symbiote-node/shapes/CommentShape.js +35 -0
  111. package/vendor/symbiote-node/shapes/DiamondShape.js +115 -0
  112. package/vendor/symbiote-node/shapes/NodeShape.js +80 -0
  113. package/vendor/symbiote-node/shapes/PillShape.js +91 -0
  114. package/vendor/symbiote-node/shapes/RectShape.js +72 -0
  115. package/vendor/symbiote-node/shapes/SVGShape.js +494 -0
  116. package/vendor/symbiote-node/shapes/index.js +53 -0
  117. package/vendor/symbiote-node/themes/Palette.js +32 -0
  118. package/vendor/symbiote-node/themes/Skin.js +113 -0
  119. package/vendor/symbiote-node/themes/Theme.js +84 -0
  120. package/vendor/symbiote-node/themes/carbon.js +137 -0
  121. package/vendor/symbiote-node/themes/dark.js +137 -0
  122. package/vendor/symbiote-node/themes/ebook.js +138 -0
  123. package/vendor/symbiote-node/themes/grey.js +137 -0
  124. package/vendor/symbiote-node/themes/light.js +137 -0
  125. package/vendor/symbiote-node/themes/neon.js +138 -0
  126. package/vendor/symbiote-node/themes/pcb.js +273 -0
  127. package/vendor/symbiote-node/themes/synthwave.js +137 -0
  128. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.css.js +86 -0
  129. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.js +128 -0
  130. package/vendor/symbiote-node/toolbar/QuickToolbar/QuickToolbar.tpl.js +29 -0
  131. package/web/app.js +9 -5
  132. package/web/components/canvas-graph.js +1705 -0
  133. package/web/components/code-block.js +1 -1
  134. package/web/components/event-feed/CodeWidget.js +32 -0
  135. package/web/components/event-feed/EventWidget.js +97 -0
  136. package/web/components/event-feed/ListWidget.js +57 -0
  137. package/web/components/event-feed/MiniGraphWidget.js +159 -0
  138. package/web/components/follow-ribbon.js +134 -0
  139. package/web/dashboard.js +1 -1
  140. package/web/follow-controller.js +241 -0
  141. package/web/index.html +4 -0
  142. package/web/panels/ActionBoard/ActionBoard.js +1 -1
  143. package/web/panels/SettingsPanel/SettingsPanel.tpl.js +1 -1
  144. package/web/panels/code-viewer.js +50 -15
  145. package/web/panels/dep-graph.js +2691 -7
  146. package/web/panels/file-tree.js +5 -2
  147. package/web/panels/live-monitor.js +75 -3
  148. package/web/style.css +39 -0
  149. package/docs/img/explorer-compact.jpg +0 -0
  150. package/docs/img/explorer-expanded.jpg +0 -0
  151. package/src/.contextignore +0 -22
  152. package/src/.project-graph-cache.json +0 -1
  153. package/src/compact/.project-graph-cache.json +0 -1
  154. package/web/.project-graph-cache.json +0 -1
  155. package/web/panels/SettingsPanel/.project-graph-cache.json +0 -1
@@ -0,0 +1,254 @@
1
+ /**
2
+ * @fileoverview ActionZone - Corner widget for split/join gestures
3
+ * Inspired by Blender's AZONE_AREA implementation.
4
+ *
5
+ * Triangular hit area at panel corners:
6
+ * - Drag inward (mouse stays inside panel) → split panel
7
+ * - Drag outward (mouse exits panel) → join panels
8
+ */
9
+
10
+ import Symbiote from '@symbiotejs/symbiote';
11
+ import { template } from './ActionZone.tpl.js';
12
+ import { styles } from './ActionZone.css.js';
13
+
14
+ /**
15
+ * Minimum drag distance before gesture is recognized
16
+ */
17
+ const DRAG_THRESHOLD = 15;
18
+
19
+ export class ActionZone extends Symbiote {
20
+ static isoMode = true;
21
+
22
+ init$ = {
23
+ // Position: 'tl' | 'tr' | 'bl' | 'br'
24
+ '@corner': 'tl',
25
+
26
+ // Panel ID (inherited from parent node)
27
+ panelId: '',
28
+
29
+ // Drag state
30
+ isDragging: false,
31
+ dragStartX: 0,
32
+ dragStartY: 0,
33
+ gestureType: null, // 'split-h' | 'split-v' | 'join'
34
+
35
+ // Panel bounds at drag start (for zone checking)
36
+ panelBounds: null,
37
+ };
38
+
39
+ renderCallback() {
40
+ // Bind pointer events directly to component
41
+ this.onpointerdown = (e) => this._onPointerDown(e);
42
+ this.onpointermove = (e) => this._onPointerMove(e);
43
+ this.onpointerup = (e) => this._onPointerUp(e);
44
+ this.onpointercancel = (e) => this._onPointerUp(e);
45
+ this.onlostpointercapture = (e) => this._onPointerUp(e);
46
+
47
+ // Global fallback for touchpad edge cases
48
+ this._globalPointerUp = (e) => {
49
+ if (this.$.isDragging) {
50
+ this._onPointerUp(e);
51
+ }
52
+ };
53
+ if (typeof document !== 'undefined') {
54
+ document.addEventListener('pointerup', this._globalPointerUp);
55
+ document.addEventListener('pointercancel', this._globalPointerUp);
56
+ }
57
+ }
58
+
59
+ disconnectedCallback() {
60
+ if (this._globalPointerUp && typeof document !== 'undefined') {
61
+ document.removeEventListener('pointerup', this._globalPointerUp);
62
+ document.removeEventListener('pointercancel', this._globalPointerUp);
63
+ }
64
+ }
65
+
66
+ /**
67
+ * Start drag operation
68
+ * @param {PointerEvent} e
69
+ */
70
+ _onPointerDown(e) {
71
+ e.preventDefault();
72
+ e.stopPropagation();
73
+
74
+ // Get panel bounds at drag start
75
+ const panelNode = this.closest('layout-node');
76
+ if (panelNode) {
77
+ const rect = panelNode.getBoundingClientRect();
78
+ this.$.panelBounds = {
79
+ left: rect.left,
80
+ top: rect.top,
81
+ right: rect.right,
82
+ bottom: rect.bottom
83
+ };
84
+ }
85
+
86
+ this.$.isDragging = true;
87
+ this.$.dragStartX = e.clientX;
88
+ this.$.dragStartY = e.clientY;
89
+ this.$.gestureType = null;
90
+
91
+ this.setPointerCapture(e.pointerId);
92
+ this.setAttribute('dragging', '');
93
+
94
+ // Notify parent to prepare for potential split/join
95
+ this.dispatchEvent(new CustomEvent('action-zone-start', {
96
+ bubbles: true,
97
+ composed: true,
98
+ detail: { panelId: this.$.panelId, corner: this.$['@corner'] }
99
+ }));
100
+ }
101
+
102
+ /**
103
+ * Track drag and detect gesture
104
+ * @param {PointerEvent} e
105
+ */
106
+ _onPointerMove(e) {
107
+ if (!this.$.isDragging) return;
108
+
109
+ const dx = e.clientX - this.$.dragStartX;
110
+ const dy = e.clientY - this.$.dragStartY;
111
+ const distance = Math.sqrt(dx * dx + dy * dy);
112
+
113
+ if (distance < DRAG_THRESHOLD) {
114
+ this.$.gestureType = null;
115
+ return;
116
+ }
117
+
118
+ // Detect gesture based on current mouse position relative to panel bounds
119
+ const gesture = this._detectGesture(e.clientX, e.clientY, dx, dy);
120
+
121
+ if (gesture !== this.$.gestureType) {
122
+ this.$.gestureType = gesture;
123
+
124
+ // Notify parent to show preview
125
+ this.dispatchEvent(new CustomEvent('action-zone-gesture', {
126
+ bubbles: true,
127
+ composed: true,
128
+ detail: {
129
+ panelId: this.$.panelId,
130
+ corner: this.$['@corner'],
131
+ gesture: gesture,
132
+ dx, dy
133
+ }
134
+ }));
135
+ }
136
+ }
137
+
138
+ /**
139
+ * Complete or cancel gesture
140
+ * @param {PointerEvent} e
141
+ */
142
+ _onPointerUp(e) {
143
+ if (!this.$.isDragging) return;
144
+
145
+ // Safe release - may fail if pointerId is invalid from global fallback
146
+ try {
147
+ if (e?.pointerId !== undefined) {
148
+ this.releasePointerCapture(e.pointerId);
149
+ }
150
+ } catch (err) {
151
+ // Ignore - pointer may already be released
152
+ }
153
+
154
+ this.removeAttribute('dragging');
155
+
156
+ const gesture = this.$.gestureType;
157
+
158
+ if (gesture) {
159
+ // Execute the gesture
160
+ this.dispatchEvent(new CustomEvent('action-zone-execute', {
161
+ bubbles: true,
162
+ composed: true,
163
+ detail: {
164
+ panelId: this.$.panelId,
165
+ corner: this.$['@corner'],
166
+ gesture: gesture
167
+ }
168
+ }));
169
+ }
170
+
171
+ // Reset state
172
+ this.$.isDragging = false;
173
+ this.$.gestureType = null;
174
+ this.$.panelBounds = null;
175
+
176
+ // Hide preview
177
+ this.dispatchEvent(new CustomEvent('action-zone-end', {
178
+ bubbles: true,
179
+ composed: true,
180
+ detail: { panelId: this.$.panelId }
181
+ }));
182
+ }
183
+
184
+ /**
185
+ * Detect gesture type based on mouse position relative to panel bounds
186
+ * @param {number} mouseX
187
+ * @param {number} mouseY
188
+ * @param {number} dx
189
+ * @param {number} dy
190
+ * @returns {'split-h' | 'split-v' | 'join' | null}
191
+ */
192
+ _detectGesture(mouseX, mouseY, dx, dy) {
193
+ const bounds = this.$.panelBounds;
194
+
195
+ if (!bounds) {
196
+ return this._detectGestureByDirection(dx, dy);
197
+ }
198
+
199
+ const isOutside = (
200
+ mouseX < bounds.left ||
201
+ mouseX > bounds.right ||
202
+ mouseY < bounds.top ||
203
+ mouseY > bounds.bottom
204
+ );
205
+
206
+ if (isOutside) {
207
+ return 'join';
208
+ }
209
+
210
+ return this._detectGestureByDirection(dx, dy);
211
+ }
212
+
213
+ /**
214
+ * Detect gesture purely by drag direction
215
+ * @param {number} dx
216
+ * @param {number} dy
217
+ * @returns {'split-h' | 'split-v' | 'join' | null}
218
+ */
219
+ _detectGestureByDirection(dx, dy) {
220
+ const corner = this.$['@corner'];
221
+ const absDx = Math.abs(dx);
222
+ const absDy = Math.abs(dy);
223
+ const isHorizontal = absDx > absDy;
224
+
225
+ let isInward = false;
226
+
227
+ switch (corner) {
228
+ case 'tl':
229
+ isInward = (isHorizontal && dx > 0) || (!isHorizontal && dy > 0);
230
+ break;
231
+ case 'tr':
232
+ isInward = (isHorizontal && dx < 0) || (!isHorizontal && dy > 0);
233
+ break;
234
+ case 'bl':
235
+ isInward = (isHorizontal && dx > 0) || (!isHorizontal && dy < 0);
236
+ break;
237
+ case 'br':
238
+ isInward = (isHorizontal && dx < 0) || (!isHorizontal && dy < 0);
239
+ break;
240
+ }
241
+
242
+ if (isInward) {
243
+ return isHorizontal ? 'split-h' : 'split-v';
244
+ } else {
245
+ return 'join';
246
+ }
247
+ }
248
+ }
249
+
250
+ ActionZone.template = template;
251
+ ActionZone.rootStyles = styles;
252
+
253
+ ActionZone.reg('action-zone');
254
+
@@ -0,0 +1,11 @@
1
+ /**
2
+ * @fileoverview ActionZone template
3
+ */
4
+
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export const template = html`
8
+ <svg viewBox="0 0 16 16" class="zone-icon">
9
+ <path d="M0,0 L16,0 L0,16 Z" fill="currentColor"/>
10
+ </svg>
11
+ `;
@@ -0,0 +1,88 @@
1
+ import { css } from '@symbiotejs/symbiote';
2
+
3
+ export const styles = css`
4
+ panel-layout {
5
+ display: block;
6
+ width: 100%;
7
+ height: 100%;
8
+ overflow: hidden;
9
+ position: relative;
10
+ font-family: var(--font-main);
11
+
12
+ &[hidden] {
13
+ display: none;
14
+ }
15
+
16
+ .layout-root {
17
+ display: flex;
18
+ width: 100%;
19
+ height: 100%;
20
+ }
21
+
22
+ /* Fullscreen tab bar */
23
+ .fullscreen-tab-bar {
24
+ position: fixed;
25
+ top: 0;
26
+ left: 0;
27
+ right: 0;
28
+ height: 28px;
29
+ background: var(--bg-deeper, #1a1a1a);
30
+ display: flex;
31
+ align-items: stretch;
32
+ gap: 0;
33
+ z-index: 10002;
34
+ padding: 0;
35
+
36
+ &[hidden] {
37
+ display: none;
38
+ }
39
+ }
40
+
41
+ .tab-list {
42
+ display: contents;
43
+ }
44
+
45
+ .fullscreen-tab {
46
+ display: flex;
47
+ align-items: center;
48
+ gap: 6px;
49
+ padding: 0 12px;
50
+ height: 28px;
51
+ border: none;
52
+ border-left: none;
53
+ border-right: none;
54
+ background: var(--bg-deeper, #1a1a1a);
55
+ color: var(--text-muted, #666);
56
+ cursor: pointer;
57
+ font-size: 12px;
58
+ font-family: inherit;
59
+ transition: background 0.15s, color 0.15s;
60
+
61
+ .material-symbols-outlined {
62
+ font-size: 16px;
63
+ }
64
+
65
+ &:hover {
66
+ background: var(--bg-header, #2d2d2d);
67
+ color: var(--text-main, #e0e0e0);
68
+ }
69
+
70
+ &[active] {
71
+ height: 29px;
72
+ margin-bottom: -1px;
73
+ position: relative;
74
+ z-index: 1;
75
+ background: var(--bg-header, #2d2d2d);
76
+ color: var(--text-main, #e0e0e0);
77
+ border-left: 1px solid var(--layout-border, #333);
78
+ border-right: 1px solid var(--layout-border, #333);
79
+ }
80
+ }
81
+
82
+ .tab-filler {
83
+ flex: 1;
84
+ height: 28px;
85
+ background: var(--bg-deeper, #1a1a1a);
86
+ }
87
+ }
88
+ `;