aboutsummaryrefslogtreecommitdiff
path: root/web
diff options
context:
space:
mode:
Diffstat (limited to 'web')
-rw-r--r--web/pw-server/src/lib/bot_code.ts15
-rw-r--r--web/pw-server/src/lib/utils.ts9
-rw-r--r--web/pw-server/src/routes/index.svelte14
3 files changed, 35 insertions, 3 deletions
diff --git a/web/pw-server/src/lib/bot_code.ts b/web/pw-server/src/lib/bot_code.ts
new file mode 100644
index 0000000..088db72
--- /dev/null
+++ b/web/pw-server/src/lib/bot_code.ts
@@ -0,0 +1,15 @@
+import defaultBotCode from "../assets/bot_template.txt?raw";
+
+const BOT_CODE_KEY = "bot_code";
+
+export function getBotCode() {
+ let botCode = localStorage.getItem(BOT_CODE_KEY);
+ if (!botCode) {
+ botCode = defaultBotCode;
+ }
+ return botCode;
+}
+
+export function saveBotCode(botCode: string) {
+ localStorage.setItem(BOT_CODE_KEY, botCode);
+}
diff --git a/web/pw-server/src/lib/utils.ts b/web/pw-server/src/lib/utils.ts
new file mode 100644
index 0000000..aab9734
--- /dev/null
+++ b/web/pw-server/src/lib/utils.ts
@@ -0,0 +1,9 @@
+export function debounce(func: Function, timeout: number = 300) {
+ let timer: ReturnType<typeof setTimeout>;
+ return (...args: any[]) => {
+ clearTimeout(timer);
+ timer = setTimeout(() => {
+ func.apply(this, args);
+ }, timeout);
+ };
+}
diff --git a/web/pw-server/src/routes/index.svelte b/web/pw-server/src/routes/index.svelte
index 56cb6f4..59552bc 100644
--- a/web/pw-server/src/routes/index.svelte
+++ b/web/pw-server/src/routes/index.svelte
@@ -9,8 +9,8 @@
import type { Ace } from "ace-builds";
import ace from "ace-builds/src-noconflict/ace?client";
import * as AcePythonMode from "ace-builds/src-noconflict/mode-python?client";
-
- import defaultBotCode from "../assets/bot_template.txt?raw";
+ import { getBotCode, saveBotCode } from "$lib/bot_code";
+ import { debounce } from "$lib/utils";
let matches = [];
@@ -24,8 +24,16 @@
});
function init_editor() {
- editSession = new ace.EditSession(defaultBotCode);
+ editSession = new ace.EditSession(getBotCode());
editSession.setMode(new AcePythonMode.Mode());
+
+ const saveCode = () => {
+ const code = editSession.getDocument().getValue();
+ saveBotCode(code);
+ };
+
+ // cast to any because the type annotations are wrong here
+ (editSession as any).on("change", debounce(saveCode, 2000));
}
async function submitCode() {