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,79 +0,0 @@
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');
@@ -1,19 +0,0 @@
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
- `;
@@ -1,41 +0,0 @@
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
- `;
@@ -1,24 +0,0 @@
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');
@@ -1,16 +0,0 @@
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
- `;
@@ -1,65 +0,0 @@
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
- `;
@@ -1,29 +0,0 @@
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');
@@ -1,13 +0,0 @@
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
- `;