move the parsing from VisualEditor to App component
This commit is contained in:
parent
65b6a343d1
commit
4f9a546fd1
11 changed files with 107 additions and 116 deletions
|
|
@ -1,9 +1,9 @@
|
|||
import { Dispatch, Ref, SetStateAction } from "react";
|
||||
import { Dispatch, memo, Ref, SetStateAction, useCallback } from "react";
|
||||
import { Statechart, stateDescription } from "../statecharts/abstract_syntax";
|
||||
import { BigStep, Environment, Mode, RaisedEvent, RT_Event } from "../statecharts/runtime_types";
|
||||
import { formatTime } from "./util";
|
||||
import { TimeMode } from "../statecharts/time";
|
||||
import { TraceState } from "./App";
|
||||
import { TraceItem, TraceState } from "./App";
|
||||
|
||||
type RTHistoryProps = {
|
||||
trace: TraceState|null,
|
||||
|
|
@ -13,52 +13,55 @@ type RTHistoryProps = {
|
|||
}
|
||||
|
||||
export function RTHistory({trace, setTrace, ast, setTime}: RTHistoryProps) {
|
||||
function gotoRt(idx: number, timestamp: number) {
|
||||
const onMouseDown = useCallback((idx: number, timestamp: number) => {
|
||||
setTrace(trace => trace && {
|
||||
...trace,
|
||||
idx,
|
||||
});
|
||||
setTime({kind: "paused", simtime: timestamp});
|
||||
}
|
||||
}, [setTrace, setTime]);
|
||||
|
||||
if (trace === null) {
|
||||
return <></>;
|
||||
}
|
||||
return <div>
|
||||
{trace.trace.map((item, i) => {
|
||||
if (item.kind === "bigstep") {
|
||||
const newStates = item.mode.difference(trace.trace[i-1]?.mode || new Set());
|
||||
return <div
|
||||
className={"runtimeState" + (i === trace.idx ? " active" : "")}
|
||||
onMouseDown={() => gotoRt(i, item.simtime)}>
|
||||
<div>
|
||||
{formatTime(item.simtime)}
|
||||
 
|
||||
<div className="inputEvent">{item.inputEvent || "<init>"}</div>
|
||||
</div>
|
||||
<ShowMode mode={newStates} statechart={ast}/>
|
||||
<ShowEnvironment environment={item.environment}/>
|
||||
{item.outputEvents.length>0 && <>^
|
||||
{item.outputEvents.map((e:RaisedEvent) => <span className="outputEvent">{e.name}</span>)}
|
||||
</>}
|
||||
</div>;
|
||||
}
|
||||
else {
|
||||
return <div className="runtimeState runtimeError">
|
||||
<div>
|
||||
{formatTime(item.simtime)}
|
||||
 
|
||||
<div className="inputEvent">{item.inputEvent}</div>
|
||||
</div>
|
||||
<div>
|
||||
{item.error.message}
|
||||
</div>
|
||||
</div>;
|
||||
}
|
||||
})}
|
||||
{trace.trace.map((item, i) => <RTHistoryItem ast={ast} idx={i} item={item} prevItem={trace.trace[i-1]} active={i === trace.idx} onMouseDown={onMouseDown}/>)}
|
||||
</div>;
|
||||
}
|
||||
|
||||
export const RTHistoryItem = memo(function RTHistoryItem({ast, idx, item, prevItem, active, onMouseDown}: {idx: number, ast: Statechart, item: TraceItem, prevItem?: TraceItem, active: boolean, onMouseDown: (idx: number, timestamp: number) => void}) {
|
||||
if (item.kind === "bigstep") {
|
||||
// @ts-ignore
|
||||
const newStates = item.mode.difference(prevItem?.mode || new Set());
|
||||
return <div
|
||||
className={"runtimeState" + (active ? " active" : "")}
|
||||
onMouseDown={useCallback(() => onMouseDown(idx, item.simtime), [idx, item.simtime])}>
|
||||
<div>
|
||||
{formatTime(item.simtime)}
|
||||
 
|
||||
<div className="inputEvent">{item.inputEvent || "<init>"}</div>
|
||||
</div>
|
||||
<ShowMode mode={newStates} statechart={ast}/>
|
||||
<ShowEnvironment environment={item.environment}/>
|
||||
{item.outputEvents.length>0 && <>^
|
||||
{item.outputEvents.map((e:RaisedEvent) => <span className="outputEvent">{e.name}</span>)}
|
||||
</>}
|
||||
</div>;
|
||||
}
|
||||
else {
|
||||
return <div className="runtimeState runtimeError">
|
||||
<div>
|
||||
{formatTime(item.simtime)}
|
||||
 
|
||||
<div className="inputEvent">{item.inputEvent}</div>
|
||||
</div>
|
||||
<div>
|
||||
{item.error.message}
|
||||
</div>
|
||||
</div>;
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
function ShowEnvironment(props: {environment: Environment}) {
|
||||
return <div>{
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue