Try removing editor

This commit is contained in:
plondon 2021-09-25 11:46:48 -04:00
parent 4ad30023f5
commit 6c7844531b
2 changed files with 13 additions and 144 deletions

View File

@ -28,43 +28,6 @@
</head> </head>
<body> <body>
<div class="columns" style="height: 100vh; margin: 0"> <div class="columns" style="height: 100vh; margin: 0">
<div class="column" style="padding: 0">
<div id="header" style="border-bottom-style: solid; border-bottom-width: 1px; border-bottom-color: lightgray">
<a href="/" class="button is-small is-info">
<span class="icon is-small">
<i class="fas fa-home"></i>
</span>
</a>
<span style="display: inline-block; vertical-align: middle; margin-left: 6px; padding-top: 2px">
<b>Riju :: <%= config.name %></b>
</span>
<span style="display: inline-block; vertical-align: middle; margin-left: 6px; padding-top: 2px">
<i id="connectionStatus" style="color: lightgray"></i>
</span>
<span style="display: inline-block; vertical-align: middle; height: 100%"></span>
<button id="runButton" type="button" class="button is-small is-success is-pulled-right">
<span>Run</span>
<span class="icon is-small">
<i class="fas fa-play"></i>
</span>
</button>
<button id="formatButton" type="button" class="button is-small is-info is-pulled-right is-hidden">
<span>Prettify</span>
<span class="icon is-small">
<i class="fas fa-code"></i>
</span>
</button>
<button id="lspButton" type="button" class="button is-small is-warning is-light is-pulled-right is-hidden">
<span>Autocomplete <span id="lspButtonState">OFF</span></span>
<span class="icon is-small">
<i class="fas fa-bolt"></i>
</span>
</button>
</div>
<div style="height: 100%">
<div id="editor" style="height: 100%; margin: 12px; margin-left: 0"></div>
</div>
</div>
<div class="column" id="terminal" style="background: black; padding: 0"> <div class="column" id="terminal" style="background: black; padding: 0">
</div> </div>
</div> </div>

View File

@ -1,11 +1,3 @@
import * as monaco from "monaco-editor";
import {
createConnection,
MonacoLanguageClient,
MonacoServices,
Services,
} from "monaco-languageclient";
import { createMessageConnection } from "vscode-jsonrpc";
import { AbstractMessageReader } from "vscode-jsonrpc/lib/messageReader.js"; import { AbstractMessageReader } from "vscode-jsonrpc/lib/messageReader.js";
import { AbstractMessageWriter } from "vscode-jsonrpc/lib/messageWriter.js"; import { AbstractMessageWriter } from "vscode-jsonrpc/lib/messageWriter.js";
import { Terminal } from "xterm"; import { Terminal } from "xterm";
@ -134,9 +126,6 @@ async function main() {
fitAddon.fit(); fitAddon.fit();
window.addEventListener("resize", () => fitAddon.fit()); window.addEventListener("resize", () => fitAddon.fit());
window.addEventListener("message", (msg) => {
console.log('message from codeamigo', msg)
})
await new Promise((resolve) => await new Promise((resolve) =>
term.write("Connecting to server...", resolve) term.write("Connecting to server...", resolve)
@ -154,6 +143,18 @@ async function main() {
} }
} }
const allowedOrigins = ["http://localhost:3000", "https://codeamigo.dev"];
window.addEventListener("message", (msg) => {
try {
if (allowedOrigins.indexOf(msg.origin) !== -1) {
sendMessage(msg.data)
}
} catch (e) {
console.log("message error: ", e)
}
console.log("message from codeamigo", msg);
});
function tryConnect() { function tryConnect() {
serviceLogBuffers = {}; serviceLogBuffers = {};
serviceLogLines = {}; serviceLogLines = {};
@ -166,9 +167,6 @@ async function main() {
document.location.host + document.location.host +
`/api/v1/ws?lang=${encodeURIComponent(config.id)}` `/api/v1/ws?lang=${encodeURIComponent(config.id)}`
); );
socket.addEventListener("error", (ev) => {
console.log(ev)
});
socket.addEventListener("open", () => { socket.addEventListener("open", () => {
connectionStatus.innerText = "connected"; connectionStatus.innerText = "connected";
console.log("Successfully connected to server"); console.log("Successfully connected to server");
@ -203,20 +201,6 @@ async function main() {
} }
term.write(message.output); term.write(message.output);
return; return;
case "formattedCode":
formatButton.disabled = false;
formatButton.classList.remove("is-loading");
if (
typeof message.code !== "string" ||
typeof message.originalCode !== "string"
) {
console.error("Unexpected message from server:", message);
return;
}
if (editor.getValue() === message.originalCode) {
editor.setValue(message.code);
}
return;
case "lspStopped": case "lspStopped":
lspButton.disabled = false; lspButton.disabled = false;
lspButton.classList.remove("is-loading"); lspButton.classList.remove("is-loading");
@ -240,50 +224,6 @@ async function main() {
console.error("Unexpected message from server:", message); console.error("Unexpected message from server:", message);
return; return;
} }
const services = MonacoServices.create(editor, {
rootUri: `file://${message.root}`,
});
servicesDisposable = Services.install(services);
const newURI = `file://${message.root}/${config.main}`;
const oldModel = editor.getModel();
if (oldModel.uri.toString() !== newURI) {
// This code is likely to be buggy as it will probably
// never run and has thus never been tested.
editor.setModel(
monaco.editor.createModel(
oldModel.getValue(),
undefined,
monaco.Uri.parse(newURI)
)
);
oldModel.dispose();
}
const connection = createMessageConnection(
new RijuMessageReader(socket),
new RijuMessageWriter(socket)
);
const client = new MonacoLanguageClient({
name: "Riju",
clientOptions: {
documentSelector: [{ pattern: "**" }],
middleware: {
workspace: {
configuration: (params, token, configuration) => {
return Array(configuration(params, token).length).fill(
config.lsp.config !== undefined ? config.lsp.config : {}
);
},
},
},
initializationOptions: config.lsp.init || {},
},
connectionProvider: {
get: (errorHandler, closeHandler) =>
Promise.resolve(
createConnection(connection, errorHandler, closeHandler)
),
},
});
clientDisposable = client.start(); clientDisposable = client.start();
return; return;
case "lspOutput": case "lspOutput":
@ -388,41 +328,7 @@ async function main() {
sendMessage({ event: "terminalInput", input: data }); sendMessage({ event: "terminalInput", input: data });
recordActivity(); recordActivity();
}); });
const editor = monaco.editor.create(document.getElementById("editor"), {
minimap: { enabled: false },
scrollbar: { verticalScrollbarSize: 0 },
});
editor.addAction({
id: "runCode",
label: "Run",
keybindings: [monaco.KeyMod.CtrlCmd | monaco.KeyCode.Enter],
contextMenuGroupId: "2_execution",
run: () => {
sendMessage({ event: "runCode", code: editor.getValue() });
},
});
editor.getModel().onDidChangeContent(() => recordActivity());
window.addEventListener("resize", () => editor.layout());
editor.getModel().setValue(config.template + "\n");
monaco.editor.setModelLanguage(
editor.getModel(),
config.monacoLang || "plaintext"
);
document.getElementById("runButton").addEventListener("click", () => {
sendMessage({ event: "runCode", code: editor.getValue() });
});
if (config.format) {
formatButton.classList.remove("is-hidden");
formatButton.addEventListener("click", () => {
formatButton.classList.add("is-loading");
formatButton.disabled = true;
serviceLogBuffers["formatter"] = "";
serviceLogLines["formatter"] = [];
sendMessage({ event: "formatCode", code: editor.getValue() });
});
}
if (config.lsp) { if (config.lsp) {
lspButton.classList.remove("is-hidden"); lspButton.classList.remove("is-hidden");
lspButton.addEventListener("click", () => { lspButton.addEventListener("click", () => {