From b04c16cb24a6e1c801c71dc681deb3a2d32cc366 Mon Sep 17 00:00:00 2001 From: Riccardo Forina Date: Wed, 20 Nov 2024 15:32:21 +0100 Subject: [PATCH] Improved external API; fixes all around --- packages/test-app/src/App.tsx | 135 +++++++++------------- packages/test-app/src/AppMachine.ts | 2 +- packages/ui/src/OpenApiEditor.tsx | 26 ++++- packages/ui/src/OpenApiEditorMachine.ts | 32 ++++- packages/ui/src/OpenApiEditorWorker.ts | 3 +- packages/ui/src/components/Toc.module.css | 4 +- packages/ui/src/components/Toc.tsx | 2 +- 7 files changed, 115 insertions(+), 89 deletions(-) diff --git a/packages/test-app/src/App.tsx b/packages/test-app/src/App.tsx index 9d2808a..9550460 100644 --- a/packages/test-app/src/App.tsx +++ b/packages/test-app/src/App.tsx @@ -4,9 +4,6 @@ import { OpenApiEditorProps, OpenApiEditorRef, } from "@apicurio-editors/ui/src"; -import { useMachine } from "@xstate/react"; -import { Loading } from "../../ui/src/components/Loading.tsx"; -import { appMachine } from "./AppMachine.ts"; import { SpecUploader } from "./components/SpecUploader"; import * as monaco from "monaco-editor"; @@ -28,8 +25,8 @@ import { TextArea, Title, } from "@patternfly/react-core"; -import { fromPromise } from "xstate"; +// initialize Monaco's workers self.MonacoEnvironment = { getWorker(_, label) { if (label === "json") { @@ -50,20 +47,7 @@ self.MonacoEnvironment = { loader.config({ monaco }); function App() { - const [state, send] = useMachine( - appMachine.provide({ - actors: { - parseSpec: fromPromise(async ({ input }) => { - if (input.spec) { - await worker.parseOasSchema(input.spec); - return true; - } - return false; - }), - }, - }), - { input: { spec: undefined } } - ); + const [spec, setSpec] = useState(null); const [captureChanges, setCaptureChanges] = useState(true); const [output, setOutput] = useState(""); @@ -72,7 +56,7 @@ function App() { const onDocumentChange: OpenApiEditorProps["onDocumentChange"] = useCallback(() => { console.log("DOCUMENT_CHANGE"); - // this should be run in a debounce + // this should probably be run in a debounce if (captureChanges && editorRef.current) { editorRef.current.getDocumentAsYaml().then((v) => { setOutput(v.substring(0, 1000)); @@ -84,78 +68,67 @@ function App() { if (editorRef.current) { const value = await editorRef.current.getDocumentAsYaml(); setOutput(value.substring(0, 1000)); - editorRef.current.updateDocument(`{ + setSpec(`{ "openapi": "3.0.3", "info": { "title": "Sample API" } }`); + // or, you could do + // editorRef.current.updateDocument(...newSpec...); } }, []); - switch (true) { - case state.matches("idle"): - return ( - send({ type: "SPEC", content })} + if (spec === null) { + return ; + } + return ( + <> + + - ); - case state.matches("parsing"): - return ; - case state.matches("parsed"): - return ( - <> - - + + + + + + + <Switch + isChecked={captureChanges} + onChange={(_, v) => setCaptureChanges(v)} + label={"Listen to onDocumentChange events"} /> - </PageSection> - <PageSection variant={"secondary"}> - <Flex> - <FlexItem> - <Button onClick={onSaveClick}>Save and update</Button> - </FlexItem> - <Title headingLevel={"h6"}> - <Switch - isChecked={captureChanges} - onChange={(_, v) => setCaptureChanges(v)} - label={"Listen to onDocumentChange events"} - /> - -