element-call/src/SequenceDiagramViewerPage.jsx

42 lines
1.2 KiB
React
Raw Normal View History

2022-02-01 23:11:06 +00:00
import React, { useCallback, useState } from "react";
import { SequenceDiagramViewer } from "./room/GroupCallInspector";
import { FieldRow, InputField } from "./input/Input";
2022-02-02 23:02:40 +00:00
import { usePageTitle } from "./usePageTitle";
2022-02-01 23:11:06 +00:00
export function SequenceDiagramViewerPage() {
2022-02-02 23:02:40 +00:00
usePageTitle("Inspector");
2022-02-01 23:11:06 +00:00
const [debugLog, setDebugLog] = useState();
const [selectedUserId, setSelectedUserId] = useState();
const onChangeDebugLog = useCallback((e) => {
if (e.target.files && e.target.files.length > 0) {
e.target.files[0].text().then((text) => {
setDebugLog(JSON.parse(text));
});
}
}, []);
return (
<div style={{ marginTop: 20 }}>
<FieldRow>
<InputField
type="file"
id="debugLog"
name="debugLog"
label="Debug Log"
onChange={onChangeDebugLog}
/>
</FieldRow>
{debugLog && (
<SequenceDiagramViewer
localUserId={debugLog.localUserId}
selectedUserId={selectedUserId}
onSelectUserId={setSelectedUserId}
remoteUserIds={debugLog.remoteUserIds}
events={debugLog.eventsByUserId[selectedUserId]}
/>
)}
</div>
);
}