From 4a85a353e3478ae01d34c88766ed6ee9fe201766 Mon Sep 17 00:00:00 2001 From: JannisDommer Date: Wed, 10 Jan 2024 15:02:08 +0100 Subject: [PATCH] refactor(examples): simplified adding examples --- .../examples.ts => assets/uvlExamples.ts} | 45 +++++-------------- WebSocketClient/index.html | 5 +-- WebSocketClient/src/main.ts | 2 +- 3 files changed, 12 insertions(+), 40 deletions(-) rename WebSocketClient/{src/examples.ts => assets/uvlExamples.ts} (62%) diff --git a/WebSocketClient/src/examples.ts b/WebSocketClient/assets/uvlExamples.ts similarity index 62% rename from WebSocketClient/src/examples.ts rename to WebSocketClient/assets/uvlExamples.ts index f476520..922f5f2 100644 --- a/WebSocketClient/src/examples.ts +++ b/WebSocketClient/assets/uvlExamples.ts @@ -6,9 +6,9 @@ let globalEditor: editor.IStandaloneCodeEditor|null; export function initExamples(editor: editor.IStandaloneCodeEditor) { globalEditor = editor; - loadDefaultExample(); - loadIceCreamExample(); - loadComputerExample(); + initExample("Default", defaultExampleText); + initExample("Ice Cream", iceCreamExampleText); + initExample("Computer", computerExampleText); } const defaultExampleText = `features @@ -75,42 +75,17 @@ constraints Dedicated => Liquid sum(powerConsumption) > 300 => StrongPSU` -function loadDefaultExample() { - const button: HTMLButtonElement|null = document.querySelector("#defaultExample"); - if(button){ +function initExample(name: string, content: string){ + const dropdown = document.getElementById("examples-dropdown"); + const button = document.createElement("button"); + if(dropdown){ + dropdown.appendChild(button); + button.innerText = name; button.onclick = () => { const opsModel = globalEditor?.getModel(); if (opsModel) { const fullModelRange = opsModel.getFullModelRange(); - const operation: IIdentifiedSingleEditOperation = {text: defaultExampleText, range: fullModelRange}; - opsModel.applyEdits([operation], false); - } - } - } -} - -function loadIceCreamExample() { - const button: HTMLButtonElement|null = document.querySelector("#iceCreamExample"); - if(button){ - button.onclick = () => { - const opsModel = globalEditor?.getModel(); - if (opsModel) { - const fullModelRange = opsModel.getFullModelRange(); - const operation: IIdentifiedSingleEditOperation = {text: iceCreamExampleText, range: fullModelRange}; - opsModel.applyEdits([operation], false); - } - } - } -} - -function loadComputerExample() { - const button: HTMLButtonElement|null = document.querySelector("#computerExample"); - if(button){ - button.onclick = () => { - const opsModel = globalEditor?.getModel(); - if (opsModel) { - const fullModelRange = opsModel.getFullModelRange(); - const operation: IIdentifiedSingleEditOperation = {text: computerExampleText, range: fullModelRange}; + const operation: IIdentifiedSingleEditOperation = {text: content, range: fullModelRange}; opsModel.applyEdits([operation], false); } } diff --git a/WebSocketClient/index.html b/WebSocketClient/index.html index f4160db..005d80b 100644 --- a/WebSocketClient/index.html +++ b/WebSocketClient/index.html @@ -30,10 +30,7 @@

UVL Playground

diff --git a/WebSocketClient/src/main.ts b/WebSocketClient/src/main.ts index 98fe22c..b8dd16f 100644 --- a/WebSocketClient/src/main.ts +++ b/WebSocketClient/src/main.ts @@ -29,7 +29,7 @@ import initUvlTutorial from './uvlTutorial.ts'; import {buildWorkerDefinition} from 'monaco-editor-workers'; import {initIntroJS} from "./intro.ts"; import {downloadFile, uploadFile} from "./ImportExportFiles.ts"; -import {initExamples} from "./examples.ts"; +import {initExamples} from "../assets/uvlExamples.ts"; import {aggregateCharacters, displayEditorError, displayEditorErrorAtContent} from "./util.ts"; import IIdentifiedSingleEditOperation = editor.IIdentifiedSingleEditOperation;