symbiote-ui 0.3.0-alpha.4

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 (322) hide show
  1. package/CHANGELOG.md +46 -0
  2. package/LICENSE +21 -0
  3. package/README.md +76 -0
  4. package/canvas/AutoLayout.js +731 -0
  5. package/canvas/Breadcrumb/Breadcrumb.css.js +75 -0
  6. package/canvas/Breadcrumb/Breadcrumb.js +96 -0
  7. package/canvas/Breadcrumb/Breadcrumb.tpl.js +7 -0
  8. package/canvas/CanvasConnectionRenderer.js +971 -0
  9. package/canvas/CanvasGraph/CanvasGraph.css.js +29 -0
  10. package/canvas/CanvasGraph/CanvasGraph.js +1697 -0
  11. package/canvas/CanvasGraph/CanvasGraphDrawState.js +280 -0
  12. package/canvas/CanvasGraph/CanvasGraphGeometry.js +194 -0
  13. package/canvas/CanvasViewport.js +550 -0
  14. package/canvas/ConnectionRenderer.js +1283 -0
  15. package/canvas/FlowSimulator.js +326 -0
  16. package/canvas/ForceLayout.js +226 -0
  17. package/canvas/ForceWorker.js +1303 -0
  18. package/canvas/FrameManager.js +223 -0
  19. package/canvas/GraphExplorerShell/GraphExplorerShell.css.js +136 -0
  20. package/canvas/GraphExplorerShell/GraphExplorerShell.js +129 -0
  21. package/canvas/GraphExplorerShell/GraphExplorerShell.tpl.js +12 -0
  22. package/canvas/GraphTabs/GraphTabs.css.js +101 -0
  23. package/canvas/GraphTabs/GraphTabs.js +189 -0
  24. package/canvas/GraphTabs/GraphTabs.tpl.js +12 -0
  25. package/canvas/LODManager.js +88 -0
  26. package/canvas/Minimap/Minimap.css.js +73 -0
  27. package/canvas/Minimap/Minimap.js +210 -0
  28. package/canvas/Minimap/Minimap.tpl.js +7 -0
  29. package/canvas/NodeCanvas/NodeCanvas.css.js +398 -0
  30. package/canvas/NodeCanvas/NodeCanvas.js +1499 -0
  31. package/canvas/NodeCanvas/NodeCanvas.tpl.js +22 -0
  32. package/canvas/NodeSearch/NodeSearch.css.js +97 -0
  33. package/canvas/NodeSearch/NodeSearch.js +140 -0
  34. package/canvas/NodeSearch/NodeSearch.tpl.js +25 -0
  35. package/canvas/NodeViewManager.js +748 -0
  36. package/canvas/PcbRouteDiagnostics.js +463 -0
  37. package/canvas/PcbRouter.js +1127 -0
  38. package/canvas/PinExpansion.js +134 -0
  39. package/canvas/PseudoConnection.js +84 -0
  40. package/canvas/SelectionSync.js +163 -0
  41. package/canvas/SubgraphManager.js +203 -0
  42. package/canvas/SubgraphRouter.js +452 -0
  43. package/canvas/ViewportActions.js +473 -0
  44. package/canvas/graph-explorer.js +339 -0
  45. package/canvas/graph-layout.js +148 -0
  46. package/canvas/graph-model.js +68 -0
  47. package/canvas/html-in-canvas.js +202 -0
  48. package/canvas/project-graph-builder.js +440 -0
  49. package/canvas/project-graph-model.js +183 -0
  50. package/chat/ChatComposer/ChatComposer.css.js +652 -0
  51. package/chat/ChatComposer/ChatComposer.js +304 -0
  52. package/chat/ChatList/ChatList.css.js +102 -0
  53. package/chat/ChatList/ChatList.js +99 -0
  54. package/chat/ChatList/ChatList.tpl.js +20 -0
  55. package/chat/ChatListItem/ChatListItem.css.js +117 -0
  56. package/chat/ChatListItem/ChatListItem.js +32 -0
  57. package/chat/ChatListItem/ChatListItem.tpl.js +17 -0
  58. package/chat/ChatMessageItem/ChatMessageItem.css.js +628 -0
  59. package/chat/ChatMessageItem/ChatMessageItem.js +156 -0
  60. package/chat/ChatSidebar/ChatSidebar.css.js +150 -0
  61. package/chat/ChatSidebar/ChatSidebar.js +230 -0
  62. package/chat/ChatSidebar/ChatSidebar.tpl.js +18 -0
  63. package/chat/ChatSidebar/constants.js +11 -0
  64. package/chat/ChatSidebarItem/ChatSidebarItem.css.js +445 -0
  65. package/chat/ChatSidebarItem/ChatSidebarItem.js +304 -0
  66. package/chat/ChatTranscript/ChatTranscript.css.js +90 -0
  67. package/chat/ChatTranscript/ChatTranscript.js +244 -0
  68. package/chat/chat-context.js +123 -0
  69. package/chat/message-model.js +156 -0
  70. package/cli.js +20 -0
  71. package/control/Button/Button.css.js +93 -0
  72. package/control/Button/Button.js +78 -0
  73. package/control/Button/Button.tpl.js +3 -0
  74. package/control/Field/Field.css.js +91 -0
  75. package/control/Field/Field.js +17 -0
  76. package/control/Field/Field.tpl.js +3 -0
  77. package/core/Connection.js +47 -0
  78. package/core/Editor.js +449 -0
  79. package/core/Frame.js +33 -0
  80. package/core/GraphMermaid.js +348 -0
  81. package/core/GraphText.js +228 -0
  82. package/core/Node.js +145 -0
  83. package/core/Portal.js +106 -0
  84. package/core/Socket.js +187 -0
  85. package/core/SubgraphNode.js +121 -0
  86. package/core/base-path.js +55 -0
  87. package/core/dom-utils.js +14 -0
  88. package/core/index.js +18 -0
  89. package/core/local-cache.js +26 -0
  90. package/core/state-sync.js +227 -0
  91. package/custom-elements.json +6380 -0
  92. package/discover.js +240 -0
  93. package/display/Badge/Badge.css.js +44 -0
  94. package/display/Badge/Badge.js +17 -0
  95. package/display/Badge/Badge.tpl.js +3 -0
  96. package/display/Banner/Banner.css.js +61 -0
  97. package/display/Banner/Banner.js +17 -0
  98. package/display/Banner/Banner.tpl.js +3 -0
  99. package/display/CodeBlock/CodeBlock.css.js +194 -0
  100. package/display/CodeBlock/CodeBlock.js +220 -0
  101. package/display/CodeBlock/CodeBlock.tpl.js +11 -0
  102. package/display/DataTable/DataTable.css.js +101 -0
  103. package/display/DataTable/DataTable.js +136 -0
  104. package/display/DataTable/DataTable.tpl.js +13 -0
  105. package/display/EmptyState/EmptyState.css.js +33 -0
  106. package/display/EmptyState/EmptyState.js +17 -0
  107. package/display/EmptyState/EmptyState.tpl.js +3 -0
  108. package/display/EventFeed/EventFeed.css.js +145 -0
  109. package/display/EventFeed/EventFeed.js +64 -0
  110. package/display/EventFeed/EventFeed.tpl.js +14 -0
  111. package/display/EventFeed/EventFeedItem.js +116 -0
  112. package/display/EventFeed/EventFeedItem.tpl.js +22 -0
  113. package/display/LoadingOverlay/LoadingOverlay.css.js +91 -0
  114. package/display/LoadingOverlay/LoadingOverlay.js +48 -0
  115. package/display/LoadingOverlay/LoadingOverlay.tpl.js +12 -0
  116. package/display/Metric/Metric.css.js +60 -0
  117. package/display/Metric/Metric.js +17 -0
  118. package/display/Metric/Metric.tpl.js +6 -0
  119. package/display/OutputGraphPreview/OutputGraphPreview.css.js +122 -0
  120. package/display/OutputGraphPreview/OutputGraphPreview.js +89 -0
  121. package/display/OutputGraphPreview/OutputGraphPreview.tpl.js +13 -0
  122. package/display/OutputListPreview/OutputListPreview.css.js +109 -0
  123. package/display/OutputListPreview/OutputListPreview.js +77 -0
  124. package/display/OutputListPreview/OutputListPreview.tpl.js +13 -0
  125. package/display/SourceEditor/SourceEditor.css.js +39 -0
  126. package/display/SourceEditor/SourceEditor.js +129 -0
  127. package/display/SourceEditor/SourceEditor.tpl.js +10 -0
  128. package/display/SourceViewer/SourceViewer.css.js +80 -0
  129. package/display/SourceViewer/SourceViewer.js +418 -0
  130. package/display/SourceViewer/SourceViewer.tpl.js +17 -0
  131. package/display/StatusRibbon/StatusRibbon.css.js +73 -0
  132. package/display/StatusRibbon/StatusRibbon.js +87 -0
  133. package/display/StatusRibbon/StatusRibbon.tpl.js +7 -0
  134. package/display/event-feed-adapter.js +72 -0
  135. package/display/format-utils.js +29 -0
  136. package/display/highlight.js +659 -0
  137. package/display/icons.js +37 -0
  138. package/display/markdown-formatter.js +60 -0
  139. package/display/network-approval-page.js +487 -0
  140. package/display/output-preview.js +261 -0
  141. package/effects/CellBg/CellBg.css.js +33 -0
  142. package/effects/CellBg/CellBg.js +410 -0
  143. package/effects/CellBg/CellBg.tpl.js +5 -0
  144. package/graph/canvas-adapter.js +223 -0
  145. package/graph/graph-algorithms.js +31 -0
  146. package/graph/index.js +46 -0
  147. package/graph/model.js +176 -0
  148. package/graph/project-graph-build.js +66 -0
  149. package/graph/project-graph-metadata.js +253 -0
  150. package/graph/project-package.js +128 -0
  151. package/graph/project-runtime.js +116 -0
  152. package/graph/project-transaction.js +284 -0
  153. package/graph/skeleton-utils.js +84 -0
  154. package/graph/theme-contract.js +36 -0
  155. package/graph/transaction-parser.js +56 -0
  156. package/icons/MaterialSymbols.js +69 -0
  157. package/icons/material-symbols-outlined-400.ttf +0 -0
  158. package/icons/material-symbols.css +24 -0
  159. package/index.js +95 -0
  160. package/inspector/InspectorPanel/InspectorPanel.css.js +375 -0
  161. package/inspector/InspectorPanel/InspectorPanel.js +368 -0
  162. package/inspector/InspectorPanel/InspectorPanel.tpl.js +96 -0
  163. package/inspector/TemplatePreview/TemplatePreview.css.js +104 -0
  164. package/inspector/TemplatePreview/TemplatePreview.js +145 -0
  165. package/inspector/TemplatePreview/TemplatePreview.tpl.js +33 -0
  166. package/interactions/ConnectFlow.js +304 -0
  167. package/interactions/Drag.js +104 -0
  168. package/interactions/Selector.js +133 -0
  169. package/interactions/SnapGrid.js +66 -0
  170. package/interactions/Zoom.js +139 -0
  171. package/layout/ActionZone/ActionZone.css.js +88 -0
  172. package/layout/ActionZone/ActionZone.js +261 -0
  173. package/layout/ActionZone/ActionZone.tpl.js +11 -0
  174. package/layout/CrossLayoutPortalBridge/CrossLayoutPortalBridge.js +255 -0
  175. package/layout/Layout/Layout.css.js +91 -0
  176. package/layout/Layout/Layout.js +637 -0
  177. package/layout/Layout/Layout.tpl.js +27 -0
  178. package/layout/LayoutNode/LayoutNode.css.js +302 -0
  179. package/layout/LayoutNode/LayoutNode.js +509 -0
  180. package/layout/LayoutNode/LayoutNode.tpl.js +39 -0
  181. package/layout/LayoutPreview/LayoutPreview.css.js +46 -0
  182. package/layout/LayoutPreview/LayoutPreview.js +102 -0
  183. package/layout/LayoutPreview/LayoutPreview.tpl.js +6 -0
  184. package/layout/LayoutRouter/LayoutRouter.js +274 -0
  185. package/layout/LayoutRouter/SectionRegistry.js +135 -0
  186. package/layout/LayoutRouter/routerSync.js +250 -0
  187. package/layout/LayoutSidebar/LayoutSidebar.css.js +411 -0
  188. package/layout/LayoutSidebar/LayoutSidebar.js +368 -0
  189. package/layout/LayoutSidebar/LayoutSidebar.tpl.js +26 -0
  190. package/layout/LayoutSidebar/SidebarSection.css.js +20 -0
  191. package/layout/LayoutSidebar/SidebarSection.js +184 -0
  192. package/layout/LayoutSidebar/SidebarSection.tpl.js +22 -0
  193. package/layout/LayoutTree.js +373 -0
  194. package/layout/PanelMenu/PanelMenu.css.js +43 -0
  195. package/layout/PanelMenu/PanelMenu.js +95 -0
  196. package/layout/PanelMenu/PanelMenu.tpl.js +17 -0
  197. package/layout/ProjectTabs/ProjectTabs.css.js +188 -0
  198. package/layout/ProjectTabs/ProjectTabs.js +77 -0
  199. package/layout/ProjectTabs/ProjectTabs.tpl.js +15 -0
  200. package/layout/index.js +40 -0
  201. package/list/ListDetailShell/ListDetailShell.css.js +128 -0
  202. package/list/ListDetailShell/ListDetailShell.js +72 -0
  203. package/list/ListDetailShell/ListDetailShell.tpl.js +36 -0
  204. package/list/ListItem/ListItem.css.js +111 -0
  205. package/list/ListItem/ListItem.js +66 -0
  206. package/list/ListItem/ListItem.tpl.js +18 -0
  207. package/locale/index.js +503 -0
  208. package/manifest/component-registry.js +2446 -0
  209. package/manifest/graph-schema.js +285 -0
  210. package/manifest/index.js +6 -0
  211. package/manifest/project-schema-catalog.js +246 -0
  212. package/manifest/rule-catalog.js +201 -0
  213. package/manifest/theme-catalog.js +2149 -0
  214. package/manifest/ui-schema-catalog.js +334 -0
  215. package/menu/ContextMenu/ContextMenu.css.js +61 -0
  216. package/menu/ContextMenu/ContextMenu.js +82 -0
  217. package/menu/ContextMenu/ContextMenu.tpl.js +19 -0
  218. package/navigation/QuickOpen/QuickOpen.css.js +92 -0
  219. package/navigation/QuickOpen/QuickOpen.js +185 -0
  220. package/navigation/QuickOpen/QuickOpen.tpl.js +15 -0
  221. package/navigation/quick-open-utils.js +101 -0
  222. package/node/CtrlItem/CtrlItem.css.js +41 -0
  223. package/node/CtrlItem/CtrlItem.js +24 -0
  224. package/node/CtrlItem/CtrlItem.tpl.js +17 -0
  225. package/node/GraphFrame/GraphFrame.css.js +66 -0
  226. package/node/GraphFrame/GraphFrame.js +32 -0
  227. package/node/GraphFrame/GraphFrame.tpl.js +13 -0
  228. package/node/GraphNode/GraphNode.css.js +815 -0
  229. package/node/GraphNode/GraphNode.js +173 -0
  230. package/node/GraphNode/GraphNode.tpl.js +33 -0
  231. package/node/NodeCallout/NodeCallout.css.js +91 -0
  232. package/node/NodeCallout/NodeCallout.js +281 -0
  233. package/node/NodeCallout/NodeCallout.tpl.js +8 -0
  234. package/node/NodeSocket/NodeSocket.css.js +68 -0
  235. package/node/NodeSocket/NodeSocket.js +26 -0
  236. package/node/NodeSocket/NodeSocket.tpl.js +7 -0
  237. package/node/PortItem/PortItem.css.js +93 -0
  238. package/node/PortItem/PortItem.js +87 -0
  239. package/node/PortItem/PortItem.tpl.js +10 -0
  240. package/package.json +165 -0
  241. package/palette/PaletteBrowser/PaletteBrowser.css.js +143 -0
  242. package/palette/PaletteBrowser/PaletteBrowser.js +152 -0
  243. package/palette/PaletteBrowser/PaletteBrowser.tpl.js +23 -0
  244. package/plugins/History.js +408 -0
  245. package/plugins/Readonly.js +60 -0
  246. package/rules/symbiote-3x.json +170 -0
  247. package/schemas/component-descriptor-v1.json +91 -0
  248. package/schemas/component-descriptor-v2.json +145 -0
  249. package/schemas/graph-model-v1.json +179 -0
  250. package/schemas/graph-v1.json +91 -0
  251. package/schemas/project-package-v1.json +102 -0
  252. package/schemas/project-transaction-v1.json +114 -0
  253. package/schemas/runtime-ui-v1.json +80 -0
  254. package/schemas/theme-rule-block-v1.json +73 -0
  255. package/shapes/CircleShape.js +79 -0
  256. package/shapes/CommentShape.js +35 -0
  257. package/shapes/DiamondShape.js +130 -0
  258. package/shapes/NodeShape.js +79 -0
  259. package/shapes/PillShape.js +91 -0
  260. package/shapes/RectShape.js +84 -0
  261. package/shapes/SVGShape.js +525 -0
  262. package/shapes/index.js +63 -0
  263. package/surface/Card/Card.css.js +57 -0
  264. package/surface/Card/Card.js +17 -0
  265. package/surface/Card/Card.tpl.js +3 -0
  266. package/themes/Palette.js +30 -0
  267. package/themes/Skin.js +113 -0
  268. package/themes/Theme.js +82 -0
  269. package/themes/carbon.js +135 -0
  270. package/themes/dark.js +140 -0
  271. package/themes/default-dark.js +714 -0
  272. package/themes/default-provider.css +635 -0
  273. package/themes/default-provider.js +718 -0
  274. package/themes/ebook.js +136 -0
  275. package/themes/grey.js +137 -0
  276. package/themes/light.js +139 -0
  277. package/themes/neon.js +138 -0
  278. package/themes/pcb.js +273 -0
  279. package/themes/synthwave.js +138 -0
  280. package/tokens/base.json +29 -0
  281. package/tokens/themes/carbon.json +11 -0
  282. package/tokens/themes/dark.json +12 -0
  283. package/tokens/themes/default-dark.json +1543 -0
  284. package/tokens/themes/default-provider.json +1543 -0
  285. package/tokens/themes/ebook.json +11 -0
  286. package/tokens/themes/grey.json +11 -0
  287. package/tokens/themes/light.json +12 -0
  288. package/tokens/themes/neon.json +11 -0
  289. package/tokens/themes/pcb.json +11 -0
  290. package/tokens/themes/synthwave.json +11 -0
  291. package/toolbar/QuickToolbar/QuickToolbar.css.js +152 -0
  292. package/toolbar/QuickToolbar/QuickToolbar.js +529 -0
  293. package/toolbar/QuickToolbar/QuickToolbar.tpl.js +34 -0
  294. package/tree/TreePanel/TreePanel.css.js +112 -0
  295. package/tree/TreePanel/TreePanel.js +147 -0
  296. package/tree/TreePanel/TreePanel.tpl.js +18 -0
  297. package/tree/TreeView/TreeView.css.js +122 -0
  298. package/tree/TreeView/TreeView.js +365 -0
  299. package/tree/TreeView/TreeView.tpl.js +10 -0
  300. package/ui/dialogs.js +221 -0
  301. package/ui/host-adapters.js +114 -0
  302. package/ui/index.js +660 -0
  303. package/ui/locale.js +50 -0
  304. package/ui/overlay-stack.js +89 -0
  305. package/ui/shared-styles.js +26 -0
  306. package/webmcp.js +37 -0
  307. package/xr/deep-graph.js +646 -0
  308. package/xr/emulation.js +198 -0
  309. package/xr/gesture.js +228 -0
  310. package/xr/html-canvas-renderer.js +472 -0
  311. package/xr/index.js +15 -0
  312. package/xr/layout-projection.js +1046 -0
  313. package/xr/panel-frame.js +128 -0
  314. package/xr/panel-host.js +267 -0
  315. package/xr/pointer.js +258 -0
  316. package/xr/scene-controller.js +242 -0
  317. package/xr/spatial-scene.js +212 -0
  318. package/xr/theme-bridge.js +105 -0
  319. package/xr/three-webxr-adapter.js +3439 -0
  320. package/xr/webgl-layer-renderer.js +419 -0
  321. package/xr/webxr.js +679 -0
  322. package/xr/workbench.js +516 -0
@@ -0,0 +1,93 @@
1
+ /**
2
+ * PortItem styles
3
+ * @module symbiote-node/node/PortItem.css
4
+ */
5
+ import { css } from '@symbiotejs/symbiote';
6
+
7
+ export let styles = css`
8
+ port-item {
9
+ display: flex;
10
+ align-items: center;
11
+ gap: 6px;
12
+ padding: 3px 12px;
13
+ min-height: 28px;
14
+
15
+ &[data-side='input'] {
16
+ flex-direction: row;
17
+
18
+ & .sn-socket {
19
+ margin-left: -22px;
20
+ }
21
+ }
22
+
23
+ &[data-side='output'] {
24
+ flex-direction: row-reverse;
25
+
26
+ & .sn-socket {
27
+ margin-right: -22px;
28
+ }
29
+ }
30
+
31
+ & .sn-socket {
32
+ position: relative;
33
+ width: calc(var(--sn-socket-size) + 8px);
34
+ height: calc(var(--sn-socket-size) + 8px);
35
+ border-radius: 50%;
36
+ background: transparent;
37
+ cursor: crosshair;
38
+ flex-shrink: 0;
39
+ z-index: 10;
40
+ display: flex;
41
+ align-items: center;
42
+ justify-content: center;
43
+
44
+ &::after {
45
+ content: '';
46
+ width: var(--sn-socket-size);
47
+ height: var(--sn-socket-size);
48
+ border-radius: 50%;
49
+ background: var(--socket-color, var(--sn-node-accent));
50
+ border: var(--sn-socket-border-width) solid var(--sn-node-bg);
51
+ transition:
52
+ transform 0.2s ease-out,
53
+ box-shadow 0.2s ease-out;
54
+ pointer-events: none;
55
+ }
56
+
57
+ &[data-socket-shape='square']::after {
58
+ border-radius: 2px;
59
+ }
60
+
61
+ &[data-socket-shape='diamond']::after {
62
+ border-radius: 1px;
63
+ transform: rotate(45deg) scale(0.85);
64
+ }
65
+
66
+ &[data-socket-shape='diamond']:hover::after {
67
+ transform: rotate(45deg) scale(1.1);
68
+ }
69
+
70
+ &[data-socket-shape='triangle']::after {
71
+ border-radius: 0;
72
+ background: transparent;
73
+ width: 0;
74
+ height: 0;
75
+ border: calc(var(--sn-socket-size) / 2) solid transparent;
76
+ border-left: calc(var(--sn-socket-size) - var(--sn-socket-border-width)) solid
77
+ var(--socket-color, var(--sn-node-accent));
78
+ border-right: none;
79
+ }
80
+
81
+ &:hover::after {
82
+ transform: scale(1.3);
83
+ box-shadow: 0 0 8px var(--socket-color, var(--sn-node-accent));
84
+ }
85
+ }
86
+
87
+ & .port-label {
88
+ color: var(--sn-text-dim);
89
+ font-size: 12px;
90
+ white-space: nowrap;
91
+ }
92
+ }
93
+ `;
@@ -0,0 +1,87 @@
1
+ /**
2
+ * PortItem — itemize item for node ports (input/output)
3
+ *
4
+ * Rendered by GraphNode via itemize API.
5
+ * Registers socket with ConnectFlow for interactive connecting.
6
+ *
7
+ * @module symbiote-node/components/PortItem
8
+ */
9
+
10
+ import Symbiote from '@symbiotejs/symbiote';
11
+ import { template } from './PortItem.tpl.js';
12
+ import { styles } from './PortItem.css.js';
13
+
14
+ export class PortItem extends Symbiote {
15
+ key = '';
16
+ label = '';
17
+ socketColor = '';
18
+ socketName = 'any';
19
+ side = 'input';
20
+
21
+ renderCallback() {
22
+ this.sub('socketColor', (val) => {
23
+ if (val) this.style.setProperty('--socket-color', val);
24
+ });
25
+ this.sub('side', (val) => {
26
+ if (val) this.setAttribute('data-side', val);
27
+ });
28
+ this.sub('socketName', (val) => {
29
+ let shape = PortItem.SOCKET_SHAPES[val] || 'circle';
30
+ let socketEl = this.ref.socket;
31
+ if (socketEl) socketEl.setAttribute('data-socket-shape', shape);
32
+ });
33
+
34
+
35
+ this.#deferRegisterSocket(0);
36
+ }
37
+
38
+ /**
39
+ * Retry registration until graph-node._canvas is available
40
+ * @param {number} attempt
41
+ */
42
+ #deferRegisterSocket(attempt) {
43
+ if (attempt > 10) return;
44
+
45
+ let socketEl = this.ref.socket;
46
+ if (!socketEl) return;
47
+
48
+ let graphNode = this.closest('graph-node');
49
+ if (!graphNode || !graphNode._canvas) {
50
+ requestAnimationFrame(() => this.#deferRegisterSocket(attempt + 1));
51
+ return;
52
+ }
53
+
54
+ let connectFlow = graphNode._canvas.getConnectFlow();
55
+ if (!connectFlow) return;
56
+
57
+ let nodeId = graphNode.getAttribute('node-id');
58
+ let key = this.$.key;
59
+ let side = this.$.side;
60
+
61
+ /** @type {import('../interactions/ConnectFlow.js').SocketData} */
62
+ let socketData = { nodeId, key, side, element: socketEl };
63
+ socketEl._socketData = socketData;
64
+
65
+ connectFlow.registerSocket(socketEl, socketData);
66
+ }
67
+ }
68
+
69
+ PortItem.template = template;
70
+ PortItem.rootStyles = styles;
71
+ PortItem.reg('port-item');
72
+
73
+ /** @type {Object<string, string>} - Socket type name to visual shape */
74
+ PortItem.SOCKET_SHAPES = {
75
+ number: 'circle',
76
+ string: 'circle',
77
+ boolean: 'circle',
78
+ any: 'circle',
79
+ array: 'square',
80
+ object: 'square',
81
+ json: 'square',
82
+ exec: 'diamond',
83
+ execution: 'diamond',
84
+ trigger: 'diamond',
85
+ event: 'triangle',
86
+ signal: 'triangle',
87
+ };
@@ -0,0 +1,10 @@
1
+ /**
2
+ * PortItem template
3
+ * @module symbiote-node/node/PortItem.tpl
4
+ */
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export let template = html`
8
+ <div ref="socket" class="sn-socket" ${{ '@data-key': 'key' }}></div>
9
+ <span class="port-label">{{label}}</span>
10
+ `;
package/package.json ADDED
@@ -0,0 +1,165 @@
1
+ {
2
+ "name": "symbiote-ui",
3
+ "version": "0.3.0-alpha.4",
4
+ "type": "module",
5
+ "description": "Symbiote provider UI, Web Components, themes, manifests, schemas, graph layout helpers, WebMCP metadata, and SSR-safe UI contracts.",
6
+ "main": "index.js",
7
+ "customElements": "custom-elements.json",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./index.js",
11
+ "default": "./index.js"
12
+ },
13
+ "./core": {
14
+ "import": "./core/index.js",
15
+ "default": "./core/index.js"
16
+ },
17
+ "./core/*": "./core/*",
18
+ "./graph": {
19
+ "import": "./graph/index.js",
20
+ "default": "./graph/index.js"
21
+ },
22
+ "./locale": {
23
+ "import": "./locale/index.js",
24
+ "default": "./locale/index.js"
25
+ },
26
+ "./manifest": {
27
+ "import": "./manifest/index.js",
28
+ "default": "./manifest/index.js"
29
+ },
30
+ "./manifest/*": "./manifest/*",
31
+ "./layout": {
32
+ "import": "./layout/index.js",
33
+ "default": "./layout/index.js"
34
+ },
35
+ "./xr": {
36
+ "import": "./xr/index.js",
37
+ "default": "./xr/index.js"
38
+ },
39
+ "./tokens/*": "./tokens/*",
40
+ "./rules/*": "./rules/*",
41
+ "./schemas/*": "./schemas/*",
42
+ "./custom-elements.json": "./custom-elements.json",
43
+ "./display/output-preview": "./display/output-preview.js",
44
+ "./display/highlight": "./display/highlight.js",
45
+ "./display/markdown-formatter": "./display/markdown-formatter.js",
46
+ "./display/format-utils": "./display/format-utils.js",
47
+ "./display/icons": "./display/icons.js",
48
+ "./display/network-approval-page": "./display/network-approval-page.js",
49
+ "./display/event-feed-adapter": "./display/event-feed-adapter.js",
50
+ "./themes/default-provider.js": "./themes/default-provider.js",
51
+ "./shapes/*": "./shapes/*",
52
+ "./plugins/*": "./plugins/*",
53
+ "./chat/chat-context.js": "./chat/chat-context.js",
54
+ "./package.json": "./package.json",
55
+ "./ui": {
56
+ "import": "./ui/index.js",
57
+ "default": "./ui/index.js"
58
+ },
59
+ "./webmcp": {
60
+ "import": "./webmcp.js",
61
+ "default": "./webmcp.js"
62
+ },
63
+ "./discover": {
64
+ "import": "./discover.js",
65
+ "default": "./discover.js"
66
+ }
67
+ },
68
+ "files": [
69
+ "index.js",
70
+ "custom-elements.json",
71
+ "core/",
72
+ "graph/",
73
+ "icons/",
74
+ "discover.js",
75
+ "cli.js",
76
+ "webmcp.js",
77
+ "manifest/",
78
+ "tokens/",
79
+ "rules/",
80
+ "schemas/",
81
+ "shapes/",
82
+ "themes/",
83
+ "plugins/",
84
+ "canvas/",
85
+ "node/",
86
+ "interactions/",
87
+ "layout/",
88
+ "locale/",
89
+ "xr/",
90
+ "navigation/",
91
+ "display/",
92
+ "effects/",
93
+ "control/",
94
+ "surface/",
95
+ "chat/",
96
+ "list/",
97
+ "tree/",
98
+ "toolbar/",
99
+ "inspector/",
100
+ "palette/",
101
+ "menu/",
102
+ "ui/",
103
+ "README.md",
104
+ "LICENSE",
105
+ "CHANGELOG.md"
106
+ ],
107
+ "sideEffects": [
108
+ "**/*.css.js",
109
+ "**/*.tpl.js",
110
+ "core/base-path.js",
111
+ "ui/index.js",
112
+ "canvas/**/*.js",
113
+ "node/**/*.js",
114
+ "layout/**/*.js",
115
+ "xr/**/*.js",
116
+ "display/**/*.js",
117
+ "effects/**/*.js",
118
+ "control/**/*.js",
119
+ "surface/**/*.js",
120
+ "chat/**/*.js",
121
+ "list/**/*.js",
122
+ "tree/**/*.js",
123
+ "navigation/**/*.js",
124
+ "toolbar/**/*.js",
125
+ "inspector/**/*.js",
126
+ "palette/**/*.js",
127
+ "menu/**/*.js"
128
+ ],
129
+ "bin": {
130
+ "symbiote-ui": "cli.js"
131
+ },
132
+ "publishConfig": {
133
+ "access": "public"
134
+ },
135
+ "scripts": {
136
+ "test": "node --test ../../tests/*.test.js"
137
+ },
138
+ "keywords": [
139
+ "node-editor",
140
+ "graph-editor",
141
+ "visual-programming",
142
+ "node-graph",
143
+ "symbiote",
144
+ "web-components",
145
+ "data-flow",
146
+ "dag",
147
+ "webmcp",
148
+ "ssr"
149
+ ],
150
+ "dependencies": {
151
+ "symbiote-engine": "0.3.0-alpha.4"
152
+ },
153
+ "peerDependencies": {
154
+ "@symbiotejs/symbiote": "3.8.0-webmcp.2"
155
+ },
156
+ "repository": {
157
+ "type": "git",
158
+ "url": "git+https://github.com/RND-PRO/symbiote-node.git"
159
+ },
160
+ "author": "RND-PRO <nicothin@gmail.com>",
161
+ "license": "MIT",
162
+ "engines": {
163
+ "node": ">=18.0.0"
164
+ }
165
+ }
@@ -0,0 +1,143 @@
1
+ /**
2
+ * PaletteBrowser styles
3
+ * @module symbiote-node/palette/PaletteBrowser.css
4
+ */
5
+ import { css } from '@symbiotejs/symbiote';
6
+
7
+ export let styles = css`
8
+ palette-browser {
9
+ display: flex;
10
+ flex-direction: column;
11
+ width: 260px;
12
+ height: 100%;
13
+ background: var(--sn-ctx-bg);
14
+ border-left: 1px solid var(--sn-node-border);
15
+ font-family: var(--sn-font);
16
+ font-size: 13px;
17
+ color: var(--sn-text);
18
+ overflow: hidden;
19
+ user-select: none;
20
+ }
21
+
22
+ .pal-header {
23
+ padding: 10px 14px;
24
+ font-weight: 600;
25
+ font-size: 12px;
26
+ text-transform: uppercase;
27
+ letter-spacing: 0.04em;
28
+ color: var(--sn-text-dim);
29
+ border-bottom: 1px solid var(--sn-node-border);
30
+ display: flex;
31
+ align-items: center;
32
+ gap: 6px;
33
+
34
+ & .material-symbols-outlined {
35
+ font-size: 16px;
36
+ }
37
+ }
38
+
39
+ .pal-search {
40
+ padding: 8px 12px;
41
+ border-bottom: 1px solid var(--sn-node-border);
42
+
43
+ & input {
44
+ width: 100%;
45
+ padding: 6px 10px;
46
+ background: var(--sn-field-control-bg);
47
+ border: 1px solid var(--sn-node-border);
48
+ border-radius: 4px;
49
+ color: var(--sn-text);
50
+ font-family: inherit;
51
+ font-size: 12px;
52
+ outline: none;
53
+ transition: border-color 0.2s ease-out;
54
+
55
+ &:focus {
56
+ border-color: var(--sn-node-selected);
57
+ }
58
+
59
+ &::placeholder {
60
+ color: var(--sn-text-dim);
61
+ }
62
+ }
63
+ }
64
+
65
+ .pal-list {
66
+ flex: 1;
67
+ overflow-y: auto;
68
+ padding: 4px 0;
69
+ }
70
+
71
+ pal-category {
72
+ & .pal-cat-header {
73
+ padding: 6px 14px;
74
+ font-size: 11px;
75
+ font-weight: 600;
76
+ color: var(--sn-text-dim);
77
+ text-transform: uppercase;
78
+ letter-spacing: 0.03em;
79
+ cursor: pointer;
80
+ display: flex;
81
+ align-items: center;
82
+ gap: 4px;
83
+
84
+ & .material-symbols-outlined {
85
+ font-size: 14px;
86
+ transition: transform 0.2s ease-out;
87
+ }
88
+
89
+ &:hover {
90
+ color: var(--sn-text);
91
+ }
92
+ }
93
+
94
+ &[data-collapsed] .pal-cat-items {
95
+ display: none;
96
+ }
97
+
98
+ &[data-collapsed] .pal-cat-header .material-symbols-outlined {
99
+ transform: rotate(-90deg);
100
+ }
101
+ }
102
+
103
+ pal-item {
104
+ padding: 6px 14px 6px 28px;
105
+ display: flex;
106
+ align-items: center;
107
+ gap: 8px;
108
+ cursor: grab;
109
+ border-radius: 4px;
110
+ margin: 1px 6px;
111
+ transition: background 0.15s ease-out;
112
+
113
+ &:hover {
114
+ background: var(--sn-ctx-hover);
115
+ }
116
+
117
+ &:active {
118
+ cursor: grabbing;
119
+ background: var(--sn-ctx-hover);
120
+ }
121
+
122
+ & .pal-item-icon {
123
+ font-size: 16px;
124
+ width: 20px;
125
+ text-align: center;
126
+ color: var(--item-color, var(--sn-text-dim));
127
+ }
128
+
129
+ & .pal-item-label {
130
+ flex: 1;
131
+ font-size: 12px;
132
+ }
133
+
134
+ & .pal-item-desc {
135
+ font-size: 10px;
136
+ color: var(--sn-text-dim);
137
+ max-width: 100px;
138
+ overflow: hidden;
139
+ text-overflow: ellipsis;
140
+ white-space: nowrap;
141
+ }
142
+ }
143
+ `;
@@ -0,0 +1,152 @@
1
+ /**
2
+ * PaletteBrowser — Component library browser panel
3
+ *
4
+ * Displays categorized node types that can be dragged onto the canvas.
5
+ * Similar to TouchDesigner's Component Palette concept.
6
+ * Shows grouped node templates with icons, descriptions, and drag support.
7
+ *
8
+ * @module symbiote-node/palette/PaletteBrowser
9
+ */
10
+
11
+ import Symbiote, { html } from '@symbiotejs/symbiote';
12
+ import { ensureMaterialSymbols } from '../../icons/MaterialSymbols.js';
13
+ import { template } from './PaletteBrowser.tpl.js';
14
+ import { styles } from './PaletteBrowser.css.js';
15
+ import { translate } from '../../locale/index.js';
16
+
17
+ class PalItem extends Symbiote {
18
+ init$ = {
19
+ name: '',
20
+ icon: 'radio_button_checked',
21
+ desc: '',
22
+ type: '',
23
+ color: '',
24
+ category: '',
25
+ isHeader: false,
26
+ };
27
+
28
+ renderCallback() {
29
+ ensureMaterialSymbols([this.$.icon]);
30
+ this.sub('icon', (icon) => ensureMaterialSymbols([icon]));
31
+ }
32
+ }
33
+
34
+ PalItem.template = html`
35
+ <span class="pal-item-icon material-symbols-outlined" ${{ textContent: 'icon' }}></span>
36
+ <span class="pal-item-label" ${{ textContent: 'name' }}></span>
37
+ <span class="pal-item-desc" ${{ textContent: 'desc' }}></span>
38
+ `;
39
+
40
+ PalItem.reg('pal-item');
41
+
42
+ class PalCategory extends Symbiote {
43
+ init$ = {
44
+ category: '',
45
+ catItems: [],
46
+ };
47
+
48
+ onToggle() {
49
+ this.toggleAttribute('data-collapsed');
50
+ }
51
+
52
+ renderCallback() {
53
+ ensureMaterialSymbols(['expand_more']);
54
+ }
55
+ }
56
+
57
+ PalCategory.template = html`
58
+ <div class="pal-cat-header" ${{ onclick: 'onToggle' }}>
59
+ <span class="material-symbols-outlined">expand_more</span>
60
+ <span ${{ textContent: 'category' }}></span>
61
+ </div>
62
+ <div class="pal-cat-items" ${{ itemize: 'catItems', 'item-tag': 'pal-item' }}></div>
63
+ `;
64
+
65
+ PalCategory.reg('pal-category');
66
+
67
+ export class PaletteBrowser extends Symbiote {
68
+ init$ = {
69
+ categories: [],
70
+ title: translate('palette.title'),
71
+ searchPlaceholder: translate('palette.searchPlaceholder'),
72
+ };
73
+
74
+ /** @type {Array<{ category: string, color: string, items: Array<{ name: string, icon: string, type: string, desc: string, factory: function }> }>} */
75
+ #rawCategories = [];
76
+
77
+ /** @type {function|null} */
78
+ #onSelect = null;
79
+
80
+ /** @type {Map<string, function>} */
81
+ #factoryMap = new Map();
82
+
83
+ renderCallback() {
84
+ ensureMaterialSymbols(['widgets']);
85
+ }
86
+
87
+ /**
88
+ * Register palette categories and items
89
+ * @param {Array<{ category: string, color: string, items: Array<{ name: string, icon: string, type: string, desc: string, factory: function }> }>} categories
90
+ */
91
+ setCategories(categories) {
92
+ this.#rawCategories = categories;
93
+ this.#syncList();
94
+ }
95
+
96
+ /**
97
+ * Set callback for item selection
98
+ * @param {function} callback - (factory, name) => void
99
+ */
100
+ onSelect(callback) {
101
+ this.#onSelect = callback;
102
+ }
103
+
104
+ #syncList(filter = '') {
105
+ let lowerFilter = filter.toLowerCase();
106
+ this.#factoryMap.clear();
107
+ ensureMaterialSymbols(this.#rawCategories.flatMap((cat) => cat.items.map((it) => it.icon)));
108
+
109
+ this.$.categories = this.#rawCategories
110
+ .map((cat) => {
111
+ let filtered = lowerFilter
112
+ ? cat.items.filter(
113
+ (it) =>
114
+ it.name.toLowerCase().includes(lowerFilter) ||
115
+ it.desc.toLowerCase().includes(lowerFilter)
116
+ )
117
+ : cat.items;
118
+
119
+ if (filtered.length === 0) return null;
120
+
121
+ let catItems = filtered.map((it) => {
122
+ this.#factoryMap.set(it.name, it.factory);
123
+ return {
124
+ name: it.name,
125
+ icon: it.icon,
126
+ desc: it.desc,
127
+ type: it.type,
128
+ color: cat.color,
129
+ };
130
+ });
131
+
132
+ return { category: cat.category, catItems };
133
+ })
134
+ .filter(Boolean);
135
+ }
136
+
137
+ onSearchInput(e) {
138
+ this.#syncList(e.target.value);
139
+ }
140
+
141
+ onItemClick(e) {
142
+ let item = e.target.closest('pal-item');
143
+ if (!item) return;
144
+ let name = item.$.name;
145
+ let factory = this.#factoryMap.get(name);
146
+ if (this.#onSelect && factory) this.#onSelect(factory, name);
147
+ }
148
+ }
149
+
150
+ PaletteBrowser.template = template;
151
+ PaletteBrowser.rootStyles = styles;
152
+ PaletteBrowser.reg('palette-browser');
@@ -0,0 +1,23 @@
1
+ /**
2
+ * PaletteBrowser template
3
+ * @module symbiote-node/palette/PaletteBrowser.tpl
4
+ */
5
+ import { html } from '@symbiotejs/symbiote';
6
+
7
+ export let template = html`
8
+ <div class="pal-header">
9
+ <span class="material-symbols-outlined">widgets</span>
10
+ <span ${{ textContent: 'title' }}></span>
11
+ </div>
12
+ <div class="pal-search">
13
+ <input
14
+ ref="palSearch"
15
+ type="text"
16
+ ${{ placeholder: 'searchPlaceholder', oninput: 'onSearchInput' }}
17
+ />
18
+ </div>
19
+ <div
20
+ class="pal-list"
21
+ ${{ itemize: 'categories', 'item-tag': 'pal-category', onclick: 'onItemClick' }}
22
+ ></div>
23
+ `;