@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.
- package/LICENSE +176 -0
- package/README.md +41 -0
- package/dist/canvas/CircuitCanvas.d.ts +45 -0
- package/dist/canvas/CircuitCanvas.d.ts.map +1 -0
- package/dist/canvas/CircuitCanvas.js +293 -0
- package/dist/canvas/CircuitCanvas.js.map +1 -0
- package/dist/canvas/ClockControls.d.ts +31 -0
- package/dist/canvas/ClockControls.d.ts.map +1 -0
- package/dist/canvas/ClockControls.js +33 -0
- package/dist/canvas/ClockControls.js.map +1 -0
- package/dist/canvas/CompositeInspectorDialog.d.ts +24 -0
- package/dist/canvas/CompositeInspectorDialog.d.ts.map +1 -0
- package/dist/canvas/CompositeInspectorDialog.js +290 -0
- package/dist/canvas/CompositeInspectorDialog.js.map +1 -0
- package/dist/canvas/dagre-layout.d.ts +40 -0
- package/dist/canvas/dagre-layout.d.ts.map +1 -0
- package/dist/canvas/dagre-layout.js +86 -0
- package/dist/canvas/dagre-layout.js.map +1 -0
- package/dist/canvas/drill-down-view.d.ts +35 -0
- package/dist/canvas/drill-down-view.d.ts.map +1 -0
- package/dist/canvas/drill-down-view.js +134 -0
- package/dist/canvas/drill-down-view.js.map +1 -0
- package/dist/canvas/hooks/useDetectTheme.d.ts +6 -0
- package/dist/canvas/hooks/useDetectTheme.d.ts.map +1 -0
- package/dist/canvas/hooks/useDetectTheme.js +20 -0
- package/dist/canvas/hooks/useDetectTheme.js.map +1 -0
- package/dist/canvas/hooks/useIsMobile.d.ts +2 -0
- package/dist/canvas/hooks/useIsMobile.d.ts.map +1 -0
- package/dist/canvas/hooks/useIsMobile.js +20 -0
- package/dist/canvas/hooks/useIsMobile.js.map +1 -0
- package/dist/canvas/hooks/useSimulationSession.d.ts +23 -0
- package/dist/canvas/hooks/useSimulationSession.d.ts.map +1 -0
- package/dist/canvas/hooks/useSimulationSession.js +41 -0
- package/dist/canvas/hooks/useSimulationSession.js.map +1 -0
- package/dist/canvas/index.d.ts +22 -0
- package/dist/canvas/index.d.ts.map +1 -0
- package/dist/canvas/index.js +17 -0
- package/dist/canvas/index.js.map +1 -0
- package/dist/canvas/label-utils.d.ts +10 -0
- package/dist/canvas/label-utils.d.ts.map +1 -0
- package/dist/canvas/label-utils.js +32 -0
- package/dist/canvas/label-utils.js.map +1 -0
- package/dist/canvas/node-types.d.ts +10 -0
- package/dist/canvas/node-types.d.ts.map +1 -0
- package/dist/canvas/node-types.js +29 -0
- package/dist/canvas/node-types.js.map +1 -0
- package/dist/canvas/projection.d.ts +19 -0
- package/dist/canvas/projection.d.ts.map +1 -0
- package/dist/canvas/projection.js +317 -0
- package/dist/canvas/projection.js.map +1 -0
- package/dist/canvas/types.d.ts +56 -0
- package/dist/canvas/types.d.ts.map +1 -0
- package/dist/canvas/types.js +6 -0
- package/dist/canvas/types.js.map +1 -0
- package/dist/canvas/useLayout.d.ts +21 -0
- package/dist/canvas/useLayout.d.ts.map +1 -0
- package/dist/canvas/useLayout.js +26 -0
- package/dist/canvas/useLayout.js.map +1 -0
- package/dist/editor/components/CircuitSelector.d.ts +9 -0
- package/dist/editor/components/CircuitSelector.d.ts.map +1 -0
- package/dist/editor/components/CircuitSelector.js +20 -0
- package/dist/editor/components/CircuitSelector.js.map +1 -0
- package/dist/editor/components/CircuitTabBar.d.ts +8 -0
- package/dist/editor/components/CircuitTabBar.d.ts.map +1 -0
- package/dist/editor/components/CircuitTabBar.js +23 -0
- package/dist/editor/components/CircuitTabBar.js.map +1 -0
- package/dist/editor/components/ClockControls.d.ts +6 -0
- package/dist/editor/components/ClockControls.d.ts.map +1 -0
- package/dist/editor/components/ClockControls.js +7 -0
- package/dist/editor/components/ClockControls.js.map +1 -0
- package/dist/editor/components/ComponentTooltip.d.ts +25 -0
- package/dist/editor/components/ComponentTooltip.d.ts.map +1 -0
- package/dist/editor/components/ComponentTooltip.js +82 -0
- package/dist/editor/components/ComponentTooltip.js.map +1 -0
- package/dist/editor/components/ConflictResolutionModal.d.ts +19 -0
- package/dist/editor/components/ConflictResolutionModal.d.ts.map +1 -0
- package/dist/editor/components/ConflictResolutionModal.js +20 -0
- package/dist/editor/components/ConflictResolutionModal.js.map +1 -0
- package/dist/editor/components/HierarchyBreadcrumb.d.ts +9 -0
- package/dist/editor/components/HierarchyBreadcrumb.d.ts.map +1 -0
- package/dist/editor/components/HierarchyBreadcrumb.js +32 -0
- package/dist/editor/components/HierarchyBreadcrumb.js.map +1 -0
- package/dist/editor/components/LabelEditor.d.ts +17 -0
- package/dist/editor/components/LabelEditor.d.ts.map +1 -0
- package/dist/editor/components/LabelEditor.js +40 -0
- package/dist/editor/components/LabelEditor.js.map +1 -0
- package/dist/editor/components/SignalOutputPanel.d.ts +11 -0
- package/dist/editor/components/SignalOutputPanel.d.ts.map +1 -0
- package/dist/editor/components/SignalOutputPanel.js +34 -0
- package/dist/editor/components/SignalOutputPanel.js.map +1 -0
- package/dist/editor/components/index.d.ts +9 -0
- package/dist/editor/components/index.d.ts.map +1 -0
- package/dist/editor/components/index.js +9 -0
- package/dist/editor/components/index.js.map +1 -0
- package/dist/editor/hooks/index.d.ts +1 -0
- package/dist/editor/hooks/index.d.ts.map +1 -0
- package/dist/editor/hooks/index.js +2 -0
- package/dist/editor/hooks/index.js.map +1 -0
- package/dist/editor/index.d.ts +5 -0
- package/dist/editor/index.d.ts.map +1 -0
- package/dist/editor/index.js +5 -0
- package/dist/editor/index.js.map +1 -0
- package/dist/editor/lib/simulation/index.d.ts +7 -0
- package/dist/editor/lib/simulation/index.d.ts.map +1 -0
- package/dist/editor/lib/simulation/index.js +8 -0
- package/dist/editor/lib/simulation/index.js.map +1 -0
- package/dist/editor/lib/utils/circuit-flattener.d.ts +29 -0
- package/dist/editor/lib/utils/circuit-flattener.d.ts.map +1 -0
- package/dist/editor/lib/utils/circuit-flattener.js +230 -0
- package/dist/editor/lib/utils/circuit-flattener.js.map +1 -0
- package/dist/editor/lib/utils/component-utils.d.ts +28 -0
- package/dist/editor/lib/utils/component-utils.d.ts.map +1 -0
- package/dist/editor/lib/utils/component-utils.js +72 -0
- package/dist/editor/lib/utils/component-utils.js.map +1 -0
- package/dist/editor/lib/utils/index.d.ts +3 -0
- package/dist/editor/lib/utils/index.d.ts.map +1 -0
- package/dist/editor/lib/utils/index.js +3 -0
- package/dist/editor/lib/utils/index.js.map +1 -0
- package/dist/editor/lib/visualization/index.d.ts +2 -0
- package/dist/editor/lib/visualization/index.d.ts.map +1 -0
- package/dist/editor/lib/visualization/index.js +2 -0
- package/dist/editor/lib/visualization/index.js.map +1 -0
- package/dist/editor/lib/visualization/vcd-generator.d.ts +63 -0
- package/dist/editor/lib/visualization/vcd-generator.d.ts.map +1 -0
- package/dist/editor/lib/visualization/vcd-generator.js +269 -0
- package/dist/editor/lib/visualization/vcd-generator.js.map +1 -0
- package/dist/editor/stores/circuit-library-store.d.ts +25 -0
- package/dist/editor/stores/circuit-library-store.d.ts.map +1 -0
- package/dist/editor/stores/circuit-library-store.js +51 -0
- package/dist/editor/stores/circuit-library-store.js.map +1 -0
- package/dist/editor/stores/circuit-preview-store.d.ts +687 -0
- package/dist/editor/stores/circuit-preview-store.d.ts.map +1 -0
- package/dist/editor/stores/circuit-preview-store.js +226 -0
- package/dist/editor/stores/circuit-preview-store.js.map +1 -0
- package/dist/editor/stores/circuit-store.d.ts +354 -0
- package/dist/editor/stores/circuit-store.d.ts.map +1 -0
- package/dist/editor/stores/circuit-store.js +227 -0
- package/dist/editor/stores/circuit-store.js.map +1 -0
- package/dist/editor/stores/index.d.ts +11 -0
- package/dist/editor/stores/index.d.ts.map +1 -0
- package/dist/editor/stores/index.js +8 -0
- package/dist/editor/stores/index.js.map +1 -0
- package/dist/editor/stores/ui-store.d.ts +96 -0
- package/dist/editor/stores/ui-store.d.ts.map +1 -0
- package/dist/editor/stores/ui-store.js +101 -0
- package/dist/editor/stores/ui-store.js.map +1 -0
- package/dist/editor/types/circuit.d.ts +207 -0
- package/dist/editor/types/circuit.d.ts.map +1 -0
- package/dist/editor/types/circuit.js +62 -0
- package/dist/editor/types/circuit.js.map +1 -0
- package/dist/editor/types/index.d.ts +12 -0
- package/dist/editor/types/index.d.ts.map +1 -0
- package/dist/editor/types/index.js +11 -0
- package/dist/editor/types/index.js.map +1 -0
- package/dist/editor/types/testbench.d.ts +150 -0
- package/dist/editor/types/testbench.d.ts.map +1 -0
- package/dist/editor/types/testbench.js +85 -0
- package/dist/editor/types/testbench.js.map +1 -0
- package/dist/editor/types/testing.d.ts +88 -0
- package/dist/editor/types/testing.d.ts.map +1 -0
- package/dist/editor/types/testing.js +6 -0
- package/dist/editor/types/testing.js.map +1 -0
- package/dist/editor/types/ui-model.d.ts +68 -0
- package/dist/editor/types/ui-model.d.ts.map +1 -0
- package/dist/editor/types/ui-model.js +66 -0
- package/dist/editor/types/ui-model.js.map +1 -0
- package/dist/editor/types/ui.d.ts +33 -0
- package/dist/editor/types/ui.d.ts.map +1 -0
- package/dist/editor/types/ui.js +8 -0
- package/dist/editor/types/ui.js.map +1 -0
- package/dist/editor/types/visual.d.ts +45 -0
- package/dist/editor/types/visual.d.ts.map +1 -0
- package/dist/editor/types/visual.js +23 -0
- package/dist/editor/types/visual.js.map +1 -0
- package/dist/editor/utils/index.d.ts +5 -0
- package/dist/editor/utils/index.d.ts.map +1 -0
- package/dist/editor/utils/index.js +6 -0
- package/dist/editor/utils/index.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/utils.d.ts +3 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +6 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/nodes/BaseNode.d.ts +20 -0
- package/dist/nodes/BaseNode.d.ts.map +1 -0
- package/dist/nodes/BaseNode.js +26 -0
- package/dist/nodes/BaseNode.js.map +1 -0
- package/dist/nodes/CompositeBadge.d.ts +6 -0
- package/dist/nodes/CompositeBadge.d.ts.map +1 -0
- package/dist/nodes/CompositeBadge.js +10 -0
- package/dist/nodes/CompositeBadge.js.map +1 -0
- package/dist/nodes/ConsoleNode.d.ts +8 -0
- package/dist/nodes/ConsoleNode.d.ts.map +1 -0
- package/dist/nodes/ConsoleNode.js +16 -0
- package/dist/nodes/ConsoleNode.js.map +1 -0
- package/dist/nodes/EmbedConsoleNode.d.ts +8 -0
- package/dist/nodes/EmbedConsoleNode.d.ts.map +1 -0
- package/dist/nodes/EmbedConsoleNode.js +24 -0
- package/dist/nodes/EmbedConsoleNode.js.map +1 -0
- package/dist/nodes/EmbedScreenNode.d.ts +8 -0
- package/dist/nodes/EmbedScreenNode.d.ts.map +1 -0
- package/dist/nodes/EmbedScreenNode.js +24 -0
- package/dist/nodes/EmbedScreenNode.js.map +1 -0
- package/dist/nodes/EthFrameInputNode.d.ts +8 -0
- package/dist/nodes/EthFrameInputNode.d.ts.map +1 -0
- package/dist/nodes/EthFrameInputNode.js +14 -0
- package/dist/nodes/EthFrameInputNode.js.map +1 -0
- package/dist/nodes/InputNode.d.ts +8 -0
- package/dist/nodes/InputNode.d.ts.map +1 -0
- package/dist/nodes/InputNode.js +57 -0
- package/dist/nodes/InputNode.js.map +1 -0
- package/dist/nodes/LogicGateNode.d.ts +8 -0
- package/dist/nodes/LogicGateNode.d.ts.map +1 -0
- package/dist/nodes/LogicGateNode.js +51 -0
- package/dist/nodes/LogicGateNode.js.map +1 -0
- package/dist/nodes/NicFifoNode.d.ts +8 -0
- package/dist/nodes/NicFifoNode.d.ts.map +1 -0
- package/dist/nodes/NicFifoNode.js +10 -0
- package/dist/nodes/NicFifoNode.js.map +1 -0
- package/dist/nodes/NodeData.d.ts +34 -0
- package/dist/nodes/NodeData.d.ts.map +1 -0
- package/dist/nodes/NodeData.js +2 -0
- package/dist/nodes/NodeData.js.map +1 -0
- package/dist/nodes/NumericInputNode.d.ts +8 -0
- package/dist/nodes/NumericInputNode.d.ts.map +1 -0
- package/dist/nodes/NumericInputNode.js +47 -0
- package/dist/nodes/NumericInputNode.js.map +1 -0
- package/dist/nodes/OutputNode.d.ts +8 -0
- package/dist/nodes/OutputNode.d.ts.map +1 -0
- package/dist/nodes/OutputNode.js +32 -0
- package/dist/nodes/OutputNode.js.map +1 -0
- package/dist/nodes/RAMNode.d.ts +8 -0
- package/dist/nodes/RAMNode.d.ts.map +1 -0
- package/dist/nodes/RAMNode.js +23 -0
- package/dist/nodes/RAMNode.js.map +1 -0
- package/dist/nodes/ROMNode.d.ts +8 -0
- package/dist/nodes/ROMNode.d.ts.map +1 -0
- package/dist/nodes/ROMNode.js +23 -0
- package/dist/nodes/ROMNode.js.map +1 -0
- package/dist/nodes/RV32IInstrMemNode.d.ts +16 -0
- package/dist/nodes/RV32IInstrMemNode.d.ts.map +1 -0
- package/dist/nodes/RV32IInstrMemNode.js +183 -0
- package/dist/nodes/RV32IInstrMemNode.js.map +1 -0
- package/dist/nodes/RasterDisplayNode.d.ts +8 -0
- package/dist/nodes/RasterDisplayNode.d.ts.map +1 -0
- package/dist/nodes/RasterDisplayNode.js +14 -0
- package/dist/nodes/RasterDisplayNode.js.map +1 -0
- package/dist/nodes/RegisterNode.d.ts +8 -0
- package/dist/nodes/RegisterNode.d.ts.map +1 -0
- package/dist/nodes/RegisterNode.js +14 -0
- package/dist/nodes/RegisterNode.js.map +1 -0
- package/dist/nodes/ScreenNode.d.ts +8 -0
- package/dist/nodes/ScreenNode.d.ts.map +1 -0
- package/dist/nodes/ScreenNode.js +16 -0
- package/dist/nodes/ScreenNode.js.map +1 -0
- package/dist/nodes/UartTxNode.d.ts +8 -0
- package/dist/nodes/UartTxNode.d.ts.map +1 -0
- package/dist/nodes/UartTxNode.js +16 -0
- package/dist/nodes/UartTxNode.js.map +1 -0
- package/dist/nodes/index.d.ts +27 -0
- package/dist/nodes/index.d.ts.map +1 -0
- package/dist/nodes/index.js +30 -0
- package/dist/nodes/index.js.map +1 -0
- package/dist/primitives/button.d.ts +12 -0
- package/dist/primitives/button.d.ts.map +1 -0
- package/dist/primitives/button.js +32 -0
- package/dist/primitives/button.js.map +1 -0
- package/dist/primitives/index.d.ts +4 -0
- package/dist/primitives/index.d.ts.map +1 -0
- package/dist/primitives/index.js +4 -0
- package/dist/primitives/index.js.map +1 -0
- package/dist/primitives/sheet.d.ts +15 -0
- package/dist/primitives/sheet.d.ts.map +1 -0
- package/dist/primitives/sheet.js +40 -0
- package/dist/primitives/sheet.js.map +1 -0
- package/dist/primitives/tooltip.d.ts +8 -0
- package/dist/primitives/tooltip.d.ts.map +1 -0
- package/dist/primitives/tooltip.js +17 -0
- package/dist/primitives/tooltip.js.map +1 -0
- package/dist/sandbox/SandboxProvider.d.ts +13 -0
- package/dist/sandbox/SandboxProvider.d.ts.map +1 -0
- package/dist/sandbox/SandboxProvider.js +34 -0
- package/dist/sandbox/SandboxProvider.js.map +1 -0
- package/dist/sandbox/index.d.ts +4 -0
- package/dist/sandbox/index.d.ts.map +1 -0
- package/dist/sandbox/index.js +3 -0
- package/dist/sandbox/index.js.map +1 -0
- package/dist/sandbox/useSandbox.d.ts +197 -0
- package/dist/sandbox/useSandbox.d.ts.map +1 -0
- package/dist/sandbox/useSandbox.js +250 -0
- package/dist/sandbox/useSandbox.js.map +1 -0
- package/dist/share/encode-source.d.ts +13 -0
- package/dist/share/encode-source.d.ts.map +1 -0
- package/dist/share/encode-source.js +31 -0
- package/dist/share/encode-source.js.map +1 -0
- package/dist/share/index.d.ts +2 -0
- package/dist/share/index.d.ts.map +1 -0
- package/dist/share/index.js +2 -0
- package/dist/share/index.js.map +1 -0
- package/dist/waveform/WaveformViewer.d.ts +30 -0
- package/dist/waveform/WaveformViewer.d.ts.map +1 -0
- package/dist/waveform/WaveformViewer.js +356 -0
- package/dist/waveform/WaveformViewer.js.map +1 -0
- 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":";AACA,OAAc,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAmB,MAAM,YAAY,CAAC;AAEvD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAOlC,SAAS,mBAAmB,CAAC,EAAE,IAAI,EAAsB;IACvD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC;IAC9B,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC;IAC5C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAE7C,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,QAAgB,EAAE,EAAE;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;QAC1D,IAAI,CAAC,aAAa,EAAE,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IAErB,MAAM,eAAe,GAAG,WAAW,CAAC,CAAC,CAAmB,EAAE,EAAE;QAC1D,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,WAAW,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC;QACrC,YAAY,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnB,MAAM,gBAAgB,GAAG,WAAW,CAAC,GAAG,EAAE;QACxC,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;YAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;QACrC,YAAY,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;IAEzB,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,CAAsB,EAAE,EAAE;QAC3D,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO;YAAE,gBAAgB,EAAE,CAAC;aACrC,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ;YAAE,YAAY,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEvB,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACvC,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;IAElF,OAAO,CACL,eAAK,SAAS,EAAC,oCAAoC,aACjD,eAAK,SAAS,EAAC,yBAAyB,aACtC,iBACE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,eAAe,EAAE,CAAC,CAAC,QAAQ,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,gBACzD,gBAAgB,EAC3B,SAAS,EAAC,qLAAqL,kBACtL,EACV,SAAS,CAAC,CAAC,CAAC,CACX,gBACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,QAAQ,EACf,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAC5C,MAAM,EAAE,gBAAgB,EACxB,SAAS,EAAE,aAAa,EACxB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,EACnC,SAAS,QACT,SAAS,EAAC,2GAA2G,GACrH,CACH,CAAC,CAAC,CAAC,CACF,kBACE,OAAO,EAAE,eAAe,gBACZ,kBAAkB,YAAY,iBAAiB,EAC3D,SAAS,EAAC,6KAA6K,mBAEpL,QAAQ,IACJ,CACV,EACD,iBACE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,eAAe,EAAE,CAAC,CAAC,QAAQ,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,gBACzD,gBAAgB,EAC3B,SAAS,EAAC,qLAAqL,kBACtL,IACP,EACN,eAAK,SAAS,EAAC,0DAA0D,mBAAI,YAAY,IAAO,IAC5F,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAkB;IAC1D,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC;IAClC,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,KAAK,OAAO,CAAC;IAErD,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,CAAmB,EAAE,EAAE;QACvD,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;IACpB,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEX,MAAM,WAAW,GAAiB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QACvE,IAAI;QACJ,KAAK;QACL,IAAI,EAAE,QAAiB;QACvB,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK;KAC/D,CAAC,CAAC,CAAC;IAEJ,OAAO,CACL,KAAC,QAAQ,IAAC,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAC,cAAc,EAAC,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,eAAe,EAAE,IAAI,CAAC,eAAe,YACxL,eAAK,SAAS,EAAC,2CAA2C,aACvD,IAAI,CAAC,WAAW,IAAI,KAAC,cAAc,KAAG,EACvC,cAAK,SAAS,EAAC,wEAAwE,YACpF,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,GAC5B,EAEL,cAAc,CAAC,CAAC,CAAC,CAChB,KAAC,mBAAmB,IAAC,IAAI,EAAE,IAAI,GAAI,CACpC,CAAC,CAAC,CAAC,CACF,8BACE,iBACE,OAAO,EAAE,YAAY,EACrB,IAAI,EAAC,QAAQ,kBACC,KAAK,gBACP,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,EAC3C,SAAS,EAAE,EAAE,CACX,8EAA8E,EAC9E,oKAAoK,EACpK,KAAK;gCACH,CAAC,CAAC,0DAA0D;gCAC5D,CAAC,CAAC,sDAAsD,CAC3D,YAED,gBACE,SAAS,EAAE,EAAE,CACX,mDAAmD,EACnD,+BAA+B,EAC/B,gDAAgD,EAChD,KAAK,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,iBAAiB,CACrD,aAED,eAAM,SAAS,EAAC,uEAAuE,GAAG,EAC1F,eACE,SAAS,EAAE,EAAE,CACX,gEAAgE,EAChE,KAAK;4CACH,CAAC,CAAC,iDAAiD;4CACnD,CAAC,CAAC,6CAA6C,CAClD,GACD,IACG,GACA,EACT,cAAK,SAAS,EAAE,EAAE,CAChB,oEAAoE,EACpE,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,oCAAoC,CAClE,YACE,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GACjB,IACL,CACJ,IACG,GACG,CACZ,CAAC;AACJ,CAAC"}
|
|
@@ -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 @@
|
|
|
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"}
|