@simten/ui 0.1.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 (307) hide show
  1. package/LICENSE +176 -0
  2. package/README.md +41 -0
  3. package/dist/canvas/CircuitCanvas.d.ts +45 -0
  4. package/dist/canvas/CircuitCanvas.d.ts.map +1 -0
  5. package/dist/canvas/CircuitCanvas.js +293 -0
  6. package/dist/canvas/CircuitCanvas.js.map +1 -0
  7. package/dist/canvas/ClockControls.d.ts +31 -0
  8. package/dist/canvas/ClockControls.d.ts.map +1 -0
  9. package/dist/canvas/ClockControls.js +33 -0
  10. package/dist/canvas/ClockControls.js.map +1 -0
  11. package/dist/canvas/CompositeInspectorDialog.d.ts +24 -0
  12. package/dist/canvas/CompositeInspectorDialog.d.ts.map +1 -0
  13. package/dist/canvas/CompositeInspectorDialog.js +290 -0
  14. package/dist/canvas/CompositeInspectorDialog.js.map +1 -0
  15. package/dist/canvas/dagre-layout.d.ts +40 -0
  16. package/dist/canvas/dagre-layout.d.ts.map +1 -0
  17. package/dist/canvas/dagre-layout.js +86 -0
  18. package/dist/canvas/dagre-layout.js.map +1 -0
  19. package/dist/canvas/drill-down-view.d.ts +35 -0
  20. package/dist/canvas/drill-down-view.d.ts.map +1 -0
  21. package/dist/canvas/drill-down-view.js +134 -0
  22. package/dist/canvas/drill-down-view.js.map +1 -0
  23. package/dist/canvas/hooks/useDetectTheme.d.ts +6 -0
  24. package/dist/canvas/hooks/useDetectTheme.d.ts.map +1 -0
  25. package/dist/canvas/hooks/useDetectTheme.js +20 -0
  26. package/dist/canvas/hooks/useDetectTheme.js.map +1 -0
  27. package/dist/canvas/hooks/useIsMobile.d.ts +2 -0
  28. package/dist/canvas/hooks/useIsMobile.d.ts.map +1 -0
  29. package/dist/canvas/hooks/useIsMobile.js +20 -0
  30. package/dist/canvas/hooks/useIsMobile.js.map +1 -0
  31. package/dist/canvas/hooks/useSimulationSession.d.ts +23 -0
  32. package/dist/canvas/hooks/useSimulationSession.d.ts.map +1 -0
  33. package/dist/canvas/hooks/useSimulationSession.js +41 -0
  34. package/dist/canvas/hooks/useSimulationSession.js.map +1 -0
  35. package/dist/canvas/index.d.ts +22 -0
  36. package/dist/canvas/index.d.ts.map +1 -0
  37. package/dist/canvas/index.js +17 -0
  38. package/dist/canvas/index.js.map +1 -0
  39. package/dist/canvas/label-utils.d.ts +10 -0
  40. package/dist/canvas/label-utils.d.ts.map +1 -0
  41. package/dist/canvas/label-utils.js +32 -0
  42. package/dist/canvas/label-utils.js.map +1 -0
  43. package/dist/canvas/node-types.d.ts +10 -0
  44. package/dist/canvas/node-types.d.ts.map +1 -0
  45. package/dist/canvas/node-types.js +29 -0
  46. package/dist/canvas/node-types.js.map +1 -0
  47. package/dist/canvas/projection.d.ts +19 -0
  48. package/dist/canvas/projection.d.ts.map +1 -0
  49. package/dist/canvas/projection.js +317 -0
  50. package/dist/canvas/projection.js.map +1 -0
  51. package/dist/canvas/types.d.ts +56 -0
  52. package/dist/canvas/types.d.ts.map +1 -0
  53. package/dist/canvas/types.js +6 -0
  54. package/dist/canvas/types.js.map +1 -0
  55. package/dist/canvas/useLayout.d.ts +21 -0
  56. package/dist/canvas/useLayout.d.ts.map +1 -0
  57. package/dist/canvas/useLayout.js +26 -0
  58. package/dist/canvas/useLayout.js.map +1 -0
  59. package/dist/editor/components/CircuitSelector.d.ts +9 -0
  60. package/dist/editor/components/CircuitSelector.d.ts.map +1 -0
  61. package/dist/editor/components/CircuitSelector.js +20 -0
  62. package/dist/editor/components/CircuitSelector.js.map +1 -0
  63. package/dist/editor/components/CircuitTabBar.d.ts +8 -0
  64. package/dist/editor/components/CircuitTabBar.d.ts.map +1 -0
  65. package/dist/editor/components/CircuitTabBar.js +23 -0
  66. package/dist/editor/components/CircuitTabBar.js.map +1 -0
  67. package/dist/editor/components/ClockControls.d.ts +6 -0
  68. package/dist/editor/components/ClockControls.d.ts.map +1 -0
  69. package/dist/editor/components/ClockControls.js +7 -0
  70. package/dist/editor/components/ClockControls.js.map +1 -0
  71. package/dist/editor/components/ComponentTooltip.d.ts +25 -0
  72. package/dist/editor/components/ComponentTooltip.d.ts.map +1 -0
  73. package/dist/editor/components/ComponentTooltip.js +82 -0
  74. package/dist/editor/components/ComponentTooltip.js.map +1 -0
  75. package/dist/editor/components/ConflictResolutionModal.d.ts +19 -0
  76. package/dist/editor/components/ConflictResolutionModal.d.ts.map +1 -0
  77. package/dist/editor/components/ConflictResolutionModal.js +20 -0
  78. package/dist/editor/components/ConflictResolutionModal.js.map +1 -0
  79. package/dist/editor/components/HierarchyBreadcrumb.d.ts +9 -0
  80. package/dist/editor/components/HierarchyBreadcrumb.d.ts.map +1 -0
  81. package/dist/editor/components/HierarchyBreadcrumb.js +32 -0
  82. package/dist/editor/components/HierarchyBreadcrumb.js.map +1 -0
  83. package/dist/editor/components/LabelEditor.d.ts +17 -0
  84. package/dist/editor/components/LabelEditor.d.ts.map +1 -0
  85. package/dist/editor/components/LabelEditor.js +40 -0
  86. package/dist/editor/components/LabelEditor.js.map +1 -0
  87. package/dist/editor/components/SignalOutputPanel.d.ts +11 -0
  88. package/dist/editor/components/SignalOutputPanel.d.ts.map +1 -0
  89. package/dist/editor/components/SignalOutputPanel.js +34 -0
  90. package/dist/editor/components/SignalOutputPanel.js.map +1 -0
  91. package/dist/editor/components/index.d.ts +9 -0
  92. package/dist/editor/components/index.d.ts.map +1 -0
  93. package/dist/editor/components/index.js +9 -0
  94. package/dist/editor/components/index.js.map +1 -0
  95. package/dist/editor/hooks/index.d.ts +1 -0
  96. package/dist/editor/hooks/index.d.ts.map +1 -0
  97. package/dist/editor/hooks/index.js +2 -0
  98. package/dist/editor/hooks/index.js.map +1 -0
  99. package/dist/editor/index.d.ts +5 -0
  100. package/dist/editor/index.d.ts.map +1 -0
  101. package/dist/editor/index.js +5 -0
  102. package/dist/editor/index.js.map +1 -0
  103. package/dist/editor/lib/simulation/index.d.ts +7 -0
  104. package/dist/editor/lib/simulation/index.d.ts.map +1 -0
  105. package/dist/editor/lib/simulation/index.js +8 -0
  106. package/dist/editor/lib/simulation/index.js.map +1 -0
  107. package/dist/editor/lib/utils/circuit-flattener.d.ts +29 -0
  108. package/dist/editor/lib/utils/circuit-flattener.d.ts.map +1 -0
  109. package/dist/editor/lib/utils/circuit-flattener.js +230 -0
  110. package/dist/editor/lib/utils/circuit-flattener.js.map +1 -0
  111. package/dist/editor/lib/utils/component-utils.d.ts +28 -0
  112. package/dist/editor/lib/utils/component-utils.d.ts.map +1 -0
  113. package/dist/editor/lib/utils/component-utils.js +72 -0
  114. package/dist/editor/lib/utils/component-utils.js.map +1 -0
  115. package/dist/editor/lib/utils/index.d.ts +3 -0
  116. package/dist/editor/lib/utils/index.d.ts.map +1 -0
  117. package/dist/editor/lib/utils/index.js +3 -0
  118. package/dist/editor/lib/utils/index.js.map +1 -0
  119. package/dist/editor/lib/visualization/index.d.ts +2 -0
  120. package/dist/editor/lib/visualization/index.d.ts.map +1 -0
  121. package/dist/editor/lib/visualization/index.js +2 -0
  122. package/dist/editor/lib/visualization/index.js.map +1 -0
  123. package/dist/editor/lib/visualization/vcd-generator.d.ts +63 -0
  124. package/dist/editor/lib/visualization/vcd-generator.d.ts.map +1 -0
  125. package/dist/editor/lib/visualization/vcd-generator.js +269 -0
  126. package/dist/editor/lib/visualization/vcd-generator.js.map +1 -0
  127. package/dist/editor/stores/circuit-library-store.d.ts +25 -0
  128. package/dist/editor/stores/circuit-library-store.d.ts.map +1 -0
  129. package/dist/editor/stores/circuit-library-store.js +51 -0
  130. package/dist/editor/stores/circuit-library-store.js.map +1 -0
  131. package/dist/editor/stores/circuit-preview-store.d.ts +687 -0
  132. package/dist/editor/stores/circuit-preview-store.d.ts.map +1 -0
  133. package/dist/editor/stores/circuit-preview-store.js +226 -0
  134. package/dist/editor/stores/circuit-preview-store.js.map +1 -0
  135. package/dist/editor/stores/circuit-store.d.ts +354 -0
  136. package/dist/editor/stores/circuit-store.d.ts.map +1 -0
  137. package/dist/editor/stores/circuit-store.js +227 -0
  138. package/dist/editor/stores/circuit-store.js.map +1 -0
  139. package/dist/editor/stores/index.d.ts +11 -0
  140. package/dist/editor/stores/index.d.ts.map +1 -0
  141. package/dist/editor/stores/index.js +8 -0
  142. package/dist/editor/stores/index.js.map +1 -0
  143. package/dist/editor/stores/ui-store.d.ts +96 -0
  144. package/dist/editor/stores/ui-store.d.ts.map +1 -0
  145. package/dist/editor/stores/ui-store.js +101 -0
  146. package/dist/editor/stores/ui-store.js.map +1 -0
  147. package/dist/editor/types/circuit.d.ts +207 -0
  148. package/dist/editor/types/circuit.d.ts.map +1 -0
  149. package/dist/editor/types/circuit.js +62 -0
  150. package/dist/editor/types/circuit.js.map +1 -0
  151. package/dist/editor/types/index.d.ts +12 -0
  152. package/dist/editor/types/index.d.ts.map +1 -0
  153. package/dist/editor/types/index.js +11 -0
  154. package/dist/editor/types/index.js.map +1 -0
  155. package/dist/editor/types/testbench.d.ts +150 -0
  156. package/dist/editor/types/testbench.d.ts.map +1 -0
  157. package/dist/editor/types/testbench.js +85 -0
  158. package/dist/editor/types/testbench.js.map +1 -0
  159. package/dist/editor/types/testing.d.ts +88 -0
  160. package/dist/editor/types/testing.d.ts.map +1 -0
  161. package/dist/editor/types/testing.js +6 -0
  162. package/dist/editor/types/testing.js.map +1 -0
  163. package/dist/editor/types/ui-model.d.ts +68 -0
  164. package/dist/editor/types/ui-model.d.ts.map +1 -0
  165. package/dist/editor/types/ui-model.js +66 -0
  166. package/dist/editor/types/ui-model.js.map +1 -0
  167. package/dist/editor/types/ui.d.ts +33 -0
  168. package/dist/editor/types/ui.d.ts.map +1 -0
  169. package/dist/editor/types/ui.js +8 -0
  170. package/dist/editor/types/ui.js.map +1 -0
  171. package/dist/editor/types/visual.d.ts +45 -0
  172. package/dist/editor/types/visual.d.ts.map +1 -0
  173. package/dist/editor/types/visual.js +23 -0
  174. package/dist/editor/types/visual.js.map +1 -0
  175. package/dist/editor/utils/index.d.ts +5 -0
  176. package/dist/editor/utils/index.d.ts.map +1 -0
  177. package/dist/editor/utils/index.js +6 -0
  178. package/dist/editor/utils/index.js.map +1 -0
  179. package/dist/index.d.ts +11 -0
  180. package/dist/index.d.ts.map +1 -0
  181. package/dist/index.js +12 -0
  182. package/dist/index.js.map +1 -0
  183. package/dist/lib/utils.d.ts +3 -0
  184. package/dist/lib/utils.d.ts.map +1 -0
  185. package/dist/lib/utils.js +6 -0
  186. package/dist/lib/utils.js.map +1 -0
  187. package/dist/nodes/BaseNode.d.ts +20 -0
  188. package/dist/nodes/BaseNode.d.ts.map +1 -0
  189. package/dist/nodes/BaseNode.js +26 -0
  190. package/dist/nodes/BaseNode.js.map +1 -0
  191. package/dist/nodes/CompositeBadge.d.ts +6 -0
  192. package/dist/nodes/CompositeBadge.d.ts.map +1 -0
  193. package/dist/nodes/CompositeBadge.js +10 -0
  194. package/dist/nodes/CompositeBadge.js.map +1 -0
  195. package/dist/nodes/ConsoleNode.d.ts +8 -0
  196. package/dist/nodes/ConsoleNode.d.ts.map +1 -0
  197. package/dist/nodes/ConsoleNode.js +16 -0
  198. package/dist/nodes/ConsoleNode.js.map +1 -0
  199. package/dist/nodes/EmbedConsoleNode.d.ts +8 -0
  200. package/dist/nodes/EmbedConsoleNode.d.ts.map +1 -0
  201. package/dist/nodes/EmbedConsoleNode.js +24 -0
  202. package/dist/nodes/EmbedConsoleNode.js.map +1 -0
  203. package/dist/nodes/EmbedScreenNode.d.ts +8 -0
  204. package/dist/nodes/EmbedScreenNode.d.ts.map +1 -0
  205. package/dist/nodes/EmbedScreenNode.js +24 -0
  206. package/dist/nodes/EmbedScreenNode.js.map +1 -0
  207. package/dist/nodes/EthFrameInputNode.d.ts +8 -0
  208. package/dist/nodes/EthFrameInputNode.d.ts.map +1 -0
  209. package/dist/nodes/EthFrameInputNode.js +14 -0
  210. package/dist/nodes/EthFrameInputNode.js.map +1 -0
  211. package/dist/nodes/InputNode.d.ts +8 -0
  212. package/dist/nodes/InputNode.d.ts.map +1 -0
  213. package/dist/nodes/InputNode.js +57 -0
  214. package/dist/nodes/InputNode.js.map +1 -0
  215. package/dist/nodes/LogicGateNode.d.ts +8 -0
  216. package/dist/nodes/LogicGateNode.d.ts.map +1 -0
  217. package/dist/nodes/LogicGateNode.js +51 -0
  218. package/dist/nodes/LogicGateNode.js.map +1 -0
  219. package/dist/nodes/NicFifoNode.d.ts +8 -0
  220. package/dist/nodes/NicFifoNode.d.ts.map +1 -0
  221. package/dist/nodes/NicFifoNode.js +10 -0
  222. package/dist/nodes/NicFifoNode.js.map +1 -0
  223. package/dist/nodes/NodeData.d.ts +34 -0
  224. package/dist/nodes/NodeData.d.ts.map +1 -0
  225. package/dist/nodes/NodeData.js +2 -0
  226. package/dist/nodes/NodeData.js.map +1 -0
  227. package/dist/nodes/NumericInputNode.d.ts +8 -0
  228. package/dist/nodes/NumericInputNode.d.ts.map +1 -0
  229. package/dist/nodes/NumericInputNode.js +47 -0
  230. package/dist/nodes/NumericInputNode.js.map +1 -0
  231. package/dist/nodes/OutputNode.d.ts +8 -0
  232. package/dist/nodes/OutputNode.d.ts.map +1 -0
  233. package/dist/nodes/OutputNode.js +32 -0
  234. package/dist/nodes/OutputNode.js.map +1 -0
  235. package/dist/nodes/RAMNode.d.ts +8 -0
  236. package/dist/nodes/RAMNode.d.ts.map +1 -0
  237. package/dist/nodes/RAMNode.js +23 -0
  238. package/dist/nodes/RAMNode.js.map +1 -0
  239. package/dist/nodes/ROMNode.d.ts +8 -0
  240. package/dist/nodes/ROMNode.d.ts.map +1 -0
  241. package/dist/nodes/ROMNode.js +23 -0
  242. package/dist/nodes/ROMNode.js.map +1 -0
  243. package/dist/nodes/RV32IInstrMemNode.d.ts +16 -0
  244. package/dist/nodes/RV32IInstrMemNode.d.ts.map +1 -0
  245. package/dist/nodes/RV32IInstrMemNode.js +183 -0
  246. package/dist/nodes/RV32IInstrMemNode.js.map +1 -0
  247. package/dist/nodes/RasterDisplayNode.d.ts +8 -0
  248. package/dist/nodes/RasterDisplayNode.d.ts.map +1 -0
  249. package/dist/nodes/RasterDisplayNode.js +14 -0
  250. package/dist/nodes/RasterDisplayNode.js.map +1 -0
  251. package/dist/nodes/RegisterNode.d.ts +8 -0
  252. package/dist/nodes/RegisterNode.d.ts.map +1 -0
  253. package/dist/nodes/RegisterNode.js +14 -0
  254. package/dist/nodes/RegisterNode.js.map +1 -0
  255. package/dist/nodes/ScreenNode.d.ts +8 -0
  256. package/dist/nodes/ScreenNode.d.ts.map +1 -0
  257. package/dist/nodes/ScreenNode.js +16 -0
  258. package/dist/nodes/ScreenNode.js.map +1 -0
  259. package/dist/nodes/UartTxNode.d.ts +8 -0
  260. package/dist/nodes/UartTxNode.d.ts.map +1 -0
  261. package/dist/nodes/UartTxNode.js +16 -0
  262. package/dist/nodes/UartTxNode.js.map +1 -0
  263. package/dist/nodes/index.d.ts +27 -0
  264. package/dist/nodes/index.d.ts.map +1 -0
  265. package/dist/nodes/index.js +30 -0
  266. package/dist/nodes/index.js.map +1 -0
  267. package/dist/primitives/button.d.ts +12 -0
  268. package/dist/primitives/button.d.ts.map +1 -0
  269. package/dist/primitives/button.js +32 -0
  270. package/dist/primitives/button.js.map +1 -0
  271. package/dist/primitives/index.d.ts +4 -0
  272. package/dist/primitives/index.d.ts.map +1 -0
  273. package/dist/primitives/index.js +4 -0
  274. package/dist/primitives/index.js.map +1 -0
  275. package/dist/primitives/sheet.d.ts +15 -0
  276. package/dist/primitives/sheet.d.ts.map +1 -0
  277. package/dist/primitives/sheet.js +40 -0
  278. package/dist/primitives/sheet.js.map +1 -0
  279. package/dist/primitives/tooltip.d.ts +8 -0
  280. package/dist/primitives/tooltip.d.ts.map +1 -0
  281. package/dist/primitives/tooltip.js +17 -0
  282. package/dist/primitives/tooltip.js.map +1 -0
  283. package/dist/sandbox/SandboxProvider.d.ts +13 -0
  284. package/dist/sandbox/SandboxProvider.d.ts.map +1 -0
  285. package/dist/sandbox/SandboxProvider.js +34 -0
  286. package/dist/sandbox/SandboxProvider.js.map +1 -0
  287. package/dist/sandbox/index.d.ts +4 -0
  288. package/dist/sandbox/index.d.ts.map +1 -0
  289. package/dist/sandbox/index.js +3 -0
  290. package/dist/sandbox/index.js.map +1 -0
  291. package/dist/sandbox/useSandbox.d.ts +197 -0
  292. package/dist/sandbox/useSandbox.d.ts.map +1 -0
  293. package/dist/sandbox/useSandbox.js +250 -0
  294. package/dist/sandbox/useSandbox.js.map +1 -0
  295. package/dist/share/encode-source.d.ts +13 -0
  296. package/dist/share/encode-source.d.ts.map +1 -0
  297. package/dist/share/encode-source.js +31 -0
  298. package/dist/share/encode-source.js.map +1 -0
  299. package/dist/share/index.d.ts +2 -0
  300. package/dist/share/index.d.ts.map +1 -0
  301. package/dist/share/index.js +2 -0
  302. package/dist/share/index.js.map +1 -0
  303. package/dist/waveform/WaveformViewer.d.ts +30 -0
  304. package/dist/waveform/WaveformViewer.d.ts.map +1 -0
  305. package/dist/waveform/WaveformViewer.js +356 -0
  306. package/dist/waveform/WaveformViewer.js.map +1 -0
  307. package/package.json +110 -0
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface InputNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function InputNode({ data, selected }: InputNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=InputNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputNode.d.ts","sourceRoot":"","sources":["../../src/nodes/InputNode.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAI3C,UAAU,cAAc;IACtB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA0ED,wBAAgB,SAAS,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,cAAc,2CAuE3D"}
@@ -0,0 +1,57 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useCallback, useState } from 'react';
3
+ import { BaseNode } from './BaseNode';
4
+ import { CompositeBadge } from './CompositeBadge';
5
+ import { cn } from '../lib/utils';
6
+ function NumericInputControl({ data }) {
7
+ const width = data.width ?? 8;
8
+ const maxValue = (1 << Math.min(width, 31)) - 1;
9
+ const currentValue = data.numericValue ?? 0;
10
+ const [isEditing, setIsEditing] = useState(false);
11
+ const [editText, setEditText] = useState('');
12
+ const setValue = useCallback((newValue) => {
13
+ const clamped = Math.max(0, Math.min(maxValue, newValue));
14
+ data.onValueChange?.(clamped);
15
+ }, [data, maxValue]);
16
+ const handleStartEdit = useCallback((e) => {
17
+ e.stopPropagation();
18
+ setEditText(currentValue.toString());
19
+ setIsEditing(true);
20
+ }, [currentValue]);
21
+ const handleFinishEdit = useCallback(() => {
22
+ const parsed = parseInt(editText, 10);
23
+ if (!isNaN(parsed))
24
+ setValue(parsed);
25
+ setIsEditing(false);
26
+ }, [editText, setValue]);
27
+ const handleKeyDown = useCallback((e) => {
28
+ e.stopPropagation();
29
+ if (e.key === 'Enter')
30
+ handleFinishEdit();
31
+ else if (e.key === 'Escape')
32
+ setIsEditing(false);
33
+ }, [handleFinishEdit]);
34
+ const hexDigits = Math.ceil(width / 4);
35
+ const hexValue = currentValue.toString(16).toUpperCase().padStart(hexDigits, '0');
36
+ return (_jsxs("div", { className: "flex flex-col items-center gap-1.5", children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("button", { onClick: (e) => { e.stopPropagation(); setValue(currentValue - 1); }, "aria-label": "Decrease value", className: "w-6 h-6 flex items-center justify-center rounded bg-[var(--embed-bg-tertiary)] hover:opacity-80 text-[var(--embed-text-secondary)] text-sm font-bold active:scale-90 transition-all", children: "-" }), isEditing ? (_jsx("input", { type: "text", value: editText, onChange: (e) => setEditText(e.target.value), onBlur: handleFinishEdit, onKeyDown: handleKeyDown, onClick: (e) => e.stopPropagation(), autoFocus: true, className: "w-14 h-7 text-center text-xs font-mono bg-white border border-blue-400 rounded outline-none text-gray-800" })) : (_jsxs("button", { onClick: handleStartEdit, "aria-label": `Current value: ${currentValue}. Click to edit`, className: "w-14 h-7 flex items-center justify-center rounded bg-[var(--embed-bg-tertiary)] text-emerald-400 font-mono text-sm font-bold hover:opacity-80 transition-colors cursor-text", children: ["0x", hexValue] })), _jsx("button", { onClick: (e) => { e.stopPropagation(); setValue(currentValue + 1); }, "aria-label": "Increase value", className: "w-6 h-6 flex items-center justify-center rounded bg-[var(--embed-bg-tertiary)] hover:opacity-80 text-[var(--embed-text-secondary)] text-sm font-bold active:scale-90 transition-all", children: "+" })] }), _jsxs("div", { className: "text-[10px] text-[var(--embed-text-secondary)] font-mono", children: ["= ", currentValue] })] }));
37
+ }
38
+ export function InputNode({ data, selected }) {
39
+ const value = data.value ?? false;
40
+ const isNumericInput = data.componentRef === 'Input';
41
+ const handleToggle = useCallback((e) => {
42
+ e.stopPropagation();
43
+ data.onToggle?.();
44
+ }, [data]);
45
+ const outputPorts = data.outputNames.map((name, index) => ({
46
+ name,
47
+ index,
48
+ type: 'output',
49
+ value: isNumericInput ? (data.numericValue ?? 0) !== 0 : value,
50
+ }));
51
+ return (_jsx(BaseNode, { outputPorts: outputPorts, selected: selected, className: "min-w-[80px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "relative flex flex-col items-center gap-2", children: [data.isComposite && _jsx(CompositeBadge, {}), _jsx("div", { className: "px-2 py-1 rounded text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || data.componentRef }), isNumericInput ? (_jsx(NumericInputControl, { data: data })) : (_jsxs(_Fragment, { children: [_jsx("button", { onClick: handleToggle, role: "switch", "aria-checked": value, "aria-label": data.label || data.componentRef, className: cn('group relative h-9 w-16 rounded-full transition-all duration-300 ease-in-out', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-blue-400 focus-visible:ring-offset-2 focus-visible:ring-offset-gray-900 hover:shadow-md active:scale-95', value
52
+ ? 'bg-gradient-to-r from-emerald-500 to-green-500 shadow-sm'
53
+ : 'bg-gradient-to-r from-gray-300 to-gray-400 shadow-sm'), children: _jsxs("span", { className: cn('absolute top-0.5 flex items-center justify-center', 'h-8 w-8 rounded-full bg-white', 'shadow-lg transition-all duration-300 ease-out', value ? 'translate-x-[1.875rem]' : 'translate-x-0.5'), children: [_jsx("span", { className: "absolute inset-1 rounded-full bg-gradient-to-br from-white to-gray-50" }), _jsx("span", { className: cn('relative z-10 h-2 w-2 rounded-full transition-all duration-300', value
54
+ ? 'bg-gradient-to-br from-emerald-400 to-green-500'
55
+ : 'bg-gradient-to-br from-gray-300 to-gray-400') })] }) }), _jsx("div", { className: cn('text-xs font-semibold tracking-wide transition-colors duration-300', value ? 'text-emerald-400' : 'text-[var(--embed-text-secondary)]'), children: value ? 'ON' : 'OFF' })] }))] }) }));
56
+ }
57
+ //# sourceMappingURL=InputNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputNode.js","sourceRoot":"","sources":["../../src/nodes/InputNode.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface LogicGateNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function LogicGateNode({ data, selected }: LogicGateNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=LogicGateNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LogicGateNode.d.ts","sourceRoot":"","sources":["../../src/nodes/LogicGateNode.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAc3C,UAAU,kBAAkB;IAC1B,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,aAAa,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,kBAAkB,2CA4DnE"}
@@ -0,0 +1,51 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { BaseNode } from './BaseNode';
3
+ import { CompositeBadge } from './CompositeBadge';
4
+ const SIMPLE_GATES = new Set([
5
+ 'And', 'Or', 'Not', 'Nand', 'Nor', 'Xor', 'Xnor', 'Buffer',
6
+ ]);
7
+ function formatComponentLabel(componentRef, args) {
8
+ if (!args || Object.keys(args).length === 0)
9
+ return componentRef;
10
+ const width = args.width ?? args.input_count;
11
+ if (width !== undefined)
12
+ return `${componentRef}(${width})`;
13
+ return componentRef;
14
+ }
15
+ export function LogicGateNode({ data, selected }) {
16
+ const value = data.value ?? false;
17
+ const inputPorts = data.inputNames.map((name, index) => ({
18
+ name,
19
+ index,
20
+ type: 'input',
21
+ }));
22
+ const outputPorts = data.outputNames.map((name, index) => ({
23
+ name,
24
+ index,
25
+ type: 'output',
26
+ value,
27
+ }));
28
+ const renderGateSymbol = () => {
29
+ const getSymbol = () => {
30
+ switch (data.componentRef) {
31
+ case 'And': return '&';
32
+ case 'Or': return '≥1';
33
+ case 'Not': return '¬';
34
+ case 'Nand': return '⊼';
35
+ case 'Nor': return '⊽';
36
+ case 'Xor': return '⊕';
37
+ case 'Xnor': return '⊙';
38
+ case 'Buffer': return '▷';
39
+ case 'DFlipFlop': return 'D';
40
+ case 'Register': return 'REG';
41
+ case 'RAM': return 'RAM';
42
+ default: return formatComponentLabel(data.componentRef, data.arguments);
43
+ }
44
+ };
45
+ const symbol = getSymbol();
46
+ const isSimple = SIMPLE_GATES.has(data.componentRef);
47
+ return (_jsx("div", { className: `flex items-center justify-center rounded-md bg-[var(--embed-bg-tertiary)] text-[var(--embed-text-primary)] ${isSimple ? 'h-12 w-12 text-2xl font-bold' : 'h-auto w-auto px-3 py-2 text-xs font-semibold'}`, children: symbol }));
48
+ };
49
+ return (_jsx(BaseNode, { inputPorts: inputPorts, outputPorts: outputPorts, selected: selected, className: "min-w-[60px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "relative flex flex-col items-center gap-1", children: [data.isComposite && _jsx(CompositeBadge, {}), _jsx("div", { className: "text-xs font-medium text-[var(--embed-text-secondary)]", children: data.label || data.componentRef }), _jsx("div", { className: "flex items-center justify-center", children: renderGateSymbol() }), data.isComposite && (_jsx("div", { className: "text-[9px] text-[var(--embed-text-muted)] italic", children: "double-click to inspect" }))] }) }));
50
+ }
51
+ //# sourceMappingURL=LogicGateNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LogicGateNode.js","sourceRoot":"","sources":["../../src/nodes/LogicGateNode.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface NicFifoNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function NicFifoNode({ data, selected }: NicFifoNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=NicFifoNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NicFifoNode.d.ts","sourceRoot":"","sources":["../../src/nodes/NicFifoNode.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3C,UAAU,gBAAgB;IACxB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,WAAW,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,gBAAgB,2CAoC/D"}
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { BaseNode } from './BaseNode';
3
+ export function NicFifoNode({ data, selected }) {
4
+ const nicState = data.__nicState;
5
+ const txCount = nicState?.txCount ?? 0;
6
+ const rxCount = nicState?.rxCount ?? 0;
7
+ const draining = nicState?.draining ?? false;
8
+ return (_jsx(BaseNode, { selected: selected, inputPorts: data.inputNames.map((name, index) => ({ name, index, type: 'input' })), outputPorts: data.outputNames.map((name, index) => ({ name, index, type: 'output' })), className: "min-w-[160px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: "px-2 py-1 text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || 'NIC' }), _jsxs("div", { className: "w-full rounded border border-[var(--embed-border-node)] bg-[var(--embed-bg-tertiary)] p-2 text-xs font-mono space-y-1", children: [_jsxs("div", { className: "flex justify-between", children: [_jsx("span", { className: "text-[var(--embed-text-secondary)]", children: "TX FIFO:" }), _jsxs("span", { className: "text-blue-400", children: [txCount, " words"] })] }), _jsxs("div", { className: "flex justify-between", children: [_jsx("span", { className: "text-[var(--embed-text-secondary)]", children: "RX FIFO:" }), _jsxs("span", { className: "text-green-400", children: [rxCount, " words"] })] }), draining && (_jsx("div", { className: "text-center text-yellow-400 font-bold", children: "TRANSMITTING" }))] })] }) }));
9
+ }
10
+ //# sourceMappingURL=NicFifoNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NicFifoNode.js","sourceRoot":"","sources":["../../src/nodes/NicFifoNode.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAQtC,MAAM,UAAU,WAAW,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAoB;IAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAiF,CAAC;IACxG,MAAM,OAAO,GAAG,QAAQ,EAAE,OAAO,IAAI,CAAC,CAAC;IACvC,MAAM,OAAO,GAAG,QAAQ,EAAE,OAAO,IAAI,CAAC,CAAC;IACvC,MAAM,QAAQ,GAAG,QAAQ,EAAE,QAAQ,IAAI,KAAK,CAAC;IAE7C,OAAO,CACL,KAAC,QAAQ,IACP,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAgB,EAAE,CAAC,CAAC,EAC3F,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAiB,EAAE,CAAC,CAAC,EAC9F,SAAS,EAAC,eAAe,EACzB,cAAc,EAAE,IAAI,CAAC,cAAc,EACnC,WAAW,EAAE,IAAI,CAAC,WAAW,EAC7B,eAAe,EAAE,IAAI,CAAC,eAAe,YAErC,eAAK,SAAS,EAAC,kCAAkC,aAC/C,cAAK,SAAS,EAAC,gEAAgE,YAC5E,IAAI,CAAC,KAAK,IAAI,KAAK,GAChB,EACN,eAAK,SAAS,EAAC,uHAAuH,aACpI,eAAK,SAAS,EAAC,sBAAsB,aACnC,eAAM,SAAS,EAAC,oCAAoC,yBAAgB,EACpE,gBAAM,SAAS,EAAC,eAAe,aAAE,OAAO,cAAc,IAClD,EACN,eAAK,SAAS,EAAC,sBAAsB,aACnC,eAAM,SAAS,EAAC,oCAAoC,yBAAgB,EACpE,gBAAM,SAAS,EAAC,gBAAgB,aAAE,OAAO,cAAc,IACnD,EACL,QAAQ,IAAI,CACX,cAAK,SAAS,EAAC,uCAAuC,6BAAmB,CAC1E,IACG,IACF,GACG,CACZ,CAAC;AACJ,CAAC"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * NodeData interface for embed node components.
3
+ * Extracted from packages/ui/src/editor/utils/projection.ts.
4
+ * No store dependencies — all interaction via callbacks.
5
+ */
6
+ export interface NodeData extends Record<string, unknown> {
7
+ nodeId: string;
8
+ componentRef: string;
9
+ label?: string;
10
+ value?: boolean;
11
+ numericValue?: number;
12
+ width?: number;
13
+ inputCount: number;
14
+ outputCount: number;
15
+ inputNames: string[];
16
+ outputNames: string[];
17
+ isComposite?: boolean;
18
+ arguments?: Record<string, unknown>;
19
+ __pixels?: number[];
20
+ __consoleText?: string;
21
+ __uartText?: string;
22
+ __nicState?: {
23
+ txCount: number;
24
+ rxCount: number;
25
+ draining: boolean;
26
+ };
27
+ onToggle?: () => void;
28
+ onValueChange?: (value: number) => void;
29
+ onLoadMemory?: (data: Map<number, number>) => void;
30
+ showPortLabels?: boolean;
31
+ onPortClick?: (portName: string, portType: 'input' | 'output') => void;
32
+ glowUnconnected?: boolean;
33
+ }
34
+ //# sourceMappingURL=NodeData.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NodeData.d.ts","sourceRoot":"","sources":["../../src/nodes/NodeData.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,QAAS,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACvD,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC;IACrE,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,IAAI,CAAC;IACnD,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,WAAW,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,GAAG,QAAQ,KAAK,IAAI,CAAC;IACvE,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=NodeData.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NodeData.js","sourceRoot":"","sources":["../../src/nodes/NodeData.ts"],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface NumericInputNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function NumericInputNode({ data, selected }: NumericInputNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=NumericInputNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumericInputNode.d.ts","sourceRoot":"","sources":["../../src/nodes/NumericInputNode.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3C,UAAU,qBAAqB;IAC7B,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,qBAAqB,2CAoFzE"}
@@ -0,0 +1,47 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useCallback, useState } from 'react';
3
+ import { BaseNode } from './BaseNode';
4
+ export function NumericInputNode({ data, selected }) {
5
+ const value = data.numericValue ?? 0;
6
+ const width = data.width ?? 8;
7
+ const maxValue = (1 << Math.min(width, 31)) - 1;
8
+ const [isEditingValue, setIsEditingValue] = useState(false);
9
+ const [editValue, setEditValue] = useState(value.toString());
10
+ const [displayMode, setDisplayMode] = useState('dec');
11
+ const handleValueClick = useCallback((e) => {
12
+ e.stopPropagation();
13
+ setEditValue(value.toString());
14
+ setIsEditingValue(true);
15
+ }, [value]);
16
+ const handleValueKeyDown = useCallback((e) => {
17
+ if (e.key === 'Enter') {
18
+ e.preventDefault();
19
+ e.stopPropagation();
20
+ const trimmed = editValue.trim();
21
+ let parsed = trimmed.toLowerCase().startsWith('0x')
22
+ ? parseInt(trimmed, 16)
23
+ : parseInt(trimmed, 10);
24
+ if (isNaN(parsed))
25
+ parsed = 0;
26
+ parsed = Math.max(0, Math.min(maxValue, parsed));
27
+ data.onValueChange?.(parsed);
28
+ setIsEditingValue(false);
29
+ }
30
+ else if (e.key === 'Escape') {
31
+ e.preventDefault();
32
+ setIsEditingValue(false);
33
+ }
34
+ }, [editValue, maxValue, data]);
35
+ const toggleDisplayMode = useCallback((e) => {
36
+ e.stopPropagation();
37
+ setDisplayMode((m) => (m === 'dec' ? 'hex' : 'dec'));
38
+ }, []);
39
+ const outputPorts = data.outputNames.map((name, index) => ({
40
+ name, index, type: 'output', value: true,
41
+ }));
42
+ const displayValue = displayMode === 'hex'
43
+ ? `0x${value.toString(16).toUpperCase().padStart(Math.ceil(width / 4), '0')}`
44
+ : value.toString();
45
+ return (_jsx(BaseNode, { outputPorts: outputPorts, selected: selected, className: "min-w-[100px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: "px-2 py-1 text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || data.componentRef }), _jsxs("div", { className: "flex flex-col items-center gap-1", children: [isEditingValue ? (_jsx("input", { type: "text", value: editValue, onChange: (e) => setEditValue(e.target.value), onKeyDown: handleValueKeyDown, onBlur: () => setIsEditingValue(false), className: "w-24 px-2 py-1 text-center font-mono text-sm border-2 border-blue-500 rounded focus:outline-none", autoFocus: true, onClick: (e) => e.stopPropagation() })) : (_jsx("div", { onClick: handleValueClick, className: "px-3 py-1 bg-gradient-to-r from-indigo-500 to-purple-500 text-white rounded cursor-pointer hover:shadow-md transition-all font-mono text-sm", title: "Click to edit value", children: displayValue })), _jsx("button", { onClick: toggleDisplayMode, className: "text-xs text-[var(--embed-text-secondary)] hover:text-[var(--embed-text-primary)] transition-colors", children: displayMode === 'dec' ? 'DEC' : 'HEX' })] }), _jsxs("div", { className: "text-xs text-[var(--embed-text-muted)]", children: [width, "-bit"] })] }) }));
46
+ }
47
+ //# sourceMappingURL=NumericInputNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NumericInputNode.js","sourceRoot":"","sources":["../../src/nodes/NumericInputNode.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface OutputNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function OutputNode({ data, selected }: OutputNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=OutputNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutputNode.d.ts","sourceRoot":"","sources":["../../src/nodes/OutputNode.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAI3C,UAAU,eAAe;IACvB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,UAAU,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,eAAe,2CA2E7D"}
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { BaseNode } from './BaseNode';
3
+ import { CompositeBadge } from './CompositeBadge';
4
+ import { cn } from '../lib/utils';
5
+ export function OutputNode({ data, selected }) {
6
+ const value = data.value ?? false;
7
+ const numericValue = data.numericValue ?? 0;
8
+ const inputPorts = data.inputNames.map((name, index) => ({
9
+ name,
10
+ index,
11
+ type: 'input',
12
+ }));
13
+ const toHexString = (num) => num.toString(16).toUpperCase().padStart(2, '0');
14
+ const renderDisplay = () => {
15
+ if (data.componentRef === 'HexDisplay') {
16
+ const hexValue = toHexString(numericValue);
17
+ return (_jsxs("div", { className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: "px-2 py-1 rounded text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || data.componentRef }), _jsx("div", { className: "flex items-center justify-center px-4 py-2 bg-black rounded border-2 border-gray-600", children: _jsx("span", { className: "text-2xl font-mono font-bold text-green-400", children: hexValue }) }), _jsxs("div", { className: "text-xs text-[var(--embed-text-secondary)]", children: ["Dec: ", numericValue] })] }));
18
+ }
19
+ else if (data.componentRef === 'SevenSegment') {
20
+ const hexDigit = (numericValue & 0xF).toString(16).toUpperCase();
21
+ return (_jsxs("div", { className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: "px-2 py-1 rounded text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || data.componentRef }), _jsx("div", { className: "flex items-center justify-center px-3 py-2 bg-black rounded border-2 border-gray-600", children: _jsx("span", { className: "text-xl font-mono font-bold text-red-500", children: hexDigit }) }), _jsxs("div", { className: "text-xs text-[var(--embed-text-secondary)]", children: ["Dec: ", numericValue & 0xF] })] }));
22
+ }
23
+ else {
24
+ // LED display (default)
25
+ return (_jsxs("div", { className: "flex flex-col items-center gap-2", children: [_jsx("div", { className: "px-2 py-1 rounded text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || data.componentRef }), _jsx("div", { className: cn('h-10 w-10 rounded-full border-2 transition-all', value
26
+ ? 'border-green-600 bg-green-400 shadow-lg shadow-green-500/50'
27
+ : 'border-gray-500 bg-[var(--embed-bg-tertiary)]'), children: value && (_jsx("div", { className: "h-full w-full rounded-full bg-gradient-to-br from-green-300 to-green-500" })) }), _jsx("div", { className: cn('text-xs font-semibold', value ? 'text-green-400' : 'text-[var(--embed-text-secondary)]'), children: value ? 'ON' : 'OFF' })] }));
28
+ }
29
+ };
30
+ return (_jsx(BaseNode, { inputPorts: inputPorts, selected: selected, className: "min-w-[80px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "relative", children: [data.isComposite && _jsx(CompositeBadge, {}), renderDisplay()] }) }));
31
+ }
32
+ //# sourceMappingURL=OutputNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutputNode.js","sourceRoot":"","sources":["../../src/nodes/OutputNode.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface RAMNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function RAMNode({ data, selected }: RAMNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=RAMNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RAMNode.d.ts","sourceRoot":"","sources":["../../src/nodes/RAMNode.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3C,UAAU,YAAY;IACpB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,YAAY,2CAqCvD"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { BaseNode } from './BaseNode';
3
+ import { CompositeBadge } from './CompositeBadge';
4
+ export function RAMNode({ data, selected }) {
5
+ const initData = data.arguments?.init;
6
+ const getInitDisplay = () => {
7
+ if (!initData)
8
+ return 'empty';
9
+ if (Array.isArray(initData))
10
+ return `[${initData.length} values]`;
11
+ if (typeof initData === 'object')
12
+ return `{${Object.keys(initData).length} entries}`;
13
+ return 'empty';
14
+ };
15
+ const inputPorts = data.inputNames.map((name, index) => ({
16
+ name, index, type: 'input',
17
+ }));
18
+ const outputPorts = data.outputNames.map((name, index) => ({
19
+ name, index, type: 'output',
20
+ }));
21
+ return (_jsx(BaseNode, { inputPorts: inputPorts, outputPorts: outputPorts, selected: selected, className: "min-w-[100px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "relative flex flex-col items-center gap-2", children: [data.isComposite && _jsx(CompositeBadge, {}), _jsx("div", { className: "px-2 py-1 text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || 'RAM' }), _jsx("div", { className: "px-3 py-2 text-xs font-semibold rounded-md bg-[var(--embed-bg-tertiary)] text-[var(--embed-text-primary)]", children: "RAM" }), _jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx("div", { className: "text-xs text-[var(--embed-text-secondary)]", children: "Init:" }), _jsx("div", { className: "px-2 py-1 bg-purple-500/20 text-purple-400 rounded font-mono text-xs", children: getInitDisplay() })] })] }) }));
22
+ }
23
+ //# sourceMappingURL=RAMNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RAMNode.js","sourceRoot":"","sources":["../../src/nodes/RAMNode.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAmB,MAAM,YAAY,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAQlD,MAAM,UAAU,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAgB;IACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;IAEtC,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,CAAC,QAAQ;YAAE,OAAO,OAAO,CAAC;QAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;YAAE,OAAO,IAAI,QAAQ,CAAC,MAAM,UAAU,CAAC;QAClE,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAAE,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,WAAW,CAAC;QACrF,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC;IAEF,MAAM,UAAU,GAAiB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACrE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO;KAC3B,CAAC,CAAC,CAAC;IAEJ,MAAM,WAAW,GAAiB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACvE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ;KAC5B,CAAC,CAAC,CAAC;IAEJ,OAAO,CACL,KAAC,QAAQ,IAAC,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAC,eAAe,EAAC,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,eAAe,EAAE,IAAI,CAAC,eAAe,YACjN,eAAK,SAAS,EAAC,2CAA2C,aACvD,IAAI,CAAC,WAAW,IAAI,KAAC,cAAc,KAAG,EACvC,cAAK,SAAS,EAAC,gEAAgE,YAC5E,IAAI,CAAC,KAAK,IAAI,KAAK,GAChB,EACN,cAAK,SAAS,EAAC,2GAA2G,oBAEpH,EACN,eAAK,SAAS,EAAC,kCAAkC,aAC/C,cAAK,SAAS,EAAC,4CAA4C,sBAAY,EACvE,cAAK,SAAS,EAAC,sEAAsE,YAClF,cAAc,EAAE,GACb,IACF,IACF,GACG,CACZ,CAAC;AACJ,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { NodeData } from './NodeData';
2
+ interface ROMNodeProps {
3
+ data: NodeData;
4
+ selected?: boolean;
5
+ }
6
+ export declare function ROMNode({ data, selected }: ROMNodeProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=ROMNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ROMNode.d.ts","sourceRoot":"","sources":["../../src/nodes/ROMNode.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3C,UAAU,YAAY;IACpB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,YAAY,2CAkCvD"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { BaseNode } from './BaseNode';
3
+ import { CompositeBadge } from './CompositeBadge';
4
+ export function ROMNode({ data, selected }) {
5
+ const initData = data.arguments?.init;
6
+ const getInitDisplay = () => {
7
+ if (!initData)
8
+ return 'empty';
9
+ if (Array.isArray(initData))
10
+ return `[${initData.length} values]`;
11
+ if (typeof initData === 'object')
12
+ return `{${Object.keys(initData).length} entries}`;
13
+ return 'empty';
14
+ };
15
+ const inputPorts = data.inputNames.map((name, index) => ({
16
+ name, index, type: 'input',
17
+ }));
18
+ const outputPorts = data.outputNames.map((name, index) => ({
19
+ name, index, type: 'output',
20
+ }));
21
+ return (_jsx(BaseNode, { inputPorts: inputPorts, outputPorts: outputPorts, selected: selected, className: "min-w-[100px]", showPortLabels: data.showPortLabels, onPortClick: data.onPortClick, glowUnconnected: data.glowUnconnected, children: _jsxs("div", { className: "relative flex flex-col items-center gap-2", children: [data.isComposite && _jsx(CompositeBadge, {}), _jsx("div", { className: "px-2 py-1 text-xs font-medium text-[var(--embed-text-primary)]", children: data.label || 'ROM' }), _jsx("div", { className: "px-3 py-2 text-xs font-semibold rounded-md bg-[var(--embed-bg-tertiary)] text-[var(--embed-text-primary)]", children: "ROM" }), _jsx("div", { className: "text-xs text-[var(--embed-text-secondary)]", children: getInitDisplay() })] }) }));
22
+ }
23
+ //# sourceMappingURL=ROMNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ROMNode.js","sourceRoot":"","sources":["../../src/nodes/ROMNode.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAmB,MAAM,YAAY,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAQlD,MAAM,UAAU,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAgB;IACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;IAEtC,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,CAAC,QAAQ;YAAE,OAAO,OAAO,CAAC;QAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;YAAE,OAAO,IAAI,QAAQ,CAAC,MAAM,UAAU,CAAC;QAClE,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAAE,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,WAAW,CAAC;QACrF,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC;IAEF,MAAM,UAAU,GAAiB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACrE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO;KAC3B,CAAC,CAAC,CAAC;IAEJ,MAAM,WAAW,GAAiB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACvE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ;KAC5B,CAAC,CAAC,CAAC;IAEJ,OAAO,CACL,KAAC,QAAQ,IAAC,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAC,eAAe,EAAC,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,eAAe,EAAE,IAAI,CAAC,eAAe,YACjN,eAAK,SAAS,EAAC,2CAA2C,aACvD,IAAI,CAAC,WAAW,IAAI,KAAC,cAAc,KAAG,EACvC,cAAK,SAAS,EAAC,gEAAgE,YAC5E,IAAI,CAAC,KAAK,IAAI,KAAK,GAChB,EACN,cAAK,SAAS,EAAC,2GAA2G,oBAEpH,EACN,cAAK,SAAS,EAAC,4CAA4C,YACxD,cAAc,EAAE,GACb,IACF,GACG,CACZ,CAAC;AACJ,CAAC"}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * RV32IInstrMemNode Component
3
+ *
4
+ * Renders RV32I instruction memory with:
5
+ * - Drag-and-drop binary file loading
6
+ * - Inline code editor with compile button (calls /api/compile)
7
+ * - Uses onLoadMemory callback to write data via engine.setNode()
8
+ */
9
+ import type { NodeData } from './NodeData';
10
+ interface RV32IInstrMemNodeProps {
11
+ data: NodeData;
12
+ selected?: boolean;
13
+ }
14
+ export declare function RV32IInstrMemNode({ data, selected }: RV32IInstrMemNodeProps): import("react/jsx-runtime").JSX.Element;
15
+ export {};
16
+ //# sourceMappingURL=RV32IInstrMemNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RV32IInstrMemNode.d.ts","sourceRoot":"","sources":["../../src/nodes/RV32IInstrMemNode.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AA8C3C,UAAU,sBAAsB;IAC9B,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,iBAAiB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,sBAAsB,2CAiQ3E"}