diff --git a/README.md b/README.md index 5ce6766..4bfdf62 100644 --- a/README.md +++ b/README.md @@ -36,3 +36,7 @@ npm run build You can preview the production build with `npm run preview`. > To deploy your app, you may need to install an [adapter](https://kit.svelte.dev/docs/adapters) for your target environment. + + + + diff --git a/package-lock.json b/package-lock.json index e7d6d75..5698b4e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -8,7 +8,9 @@ "name": "openbirchmockupsite", "version": "0.0.1", "dependencies": { - "svelte-parallax": "^0.6.0" + "linq": "^4.0.3", + "svelte-parallax": "^0.6.0", + "theme-change": "^2.5.0" }, "devDependencies": { "@fontsource/fira-mono": "^4.5.10", @@ -1748,6 +1750,15 @@ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", "dev": true }, + "node_modules/linq": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/linq/-/linq-4.0.3.tgz", + "integrity": "sha512-dP0w2ERJXfVUk6VmmAK+Tz/SxFHwyY7VM6Mrq4fnJmeQf9JNEYFH6qJfV6Qn0N91mfwz2GEE/4S+RDkmDNyUJw==", + "license": "MIT", + "engines": { + "node": "*" + } + }, "node_modules/locate-character": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/locate-character/-/locate-character-3.0.0.tgz", @@ -2831,6 +2842,12 @@ "node": ">=10.13.0" } }, + "node_modules/theme-change": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/theme-change/-/theme-change-2.5.0.tgz", + "integrity": "sha512-B/UdsgdHAGhSKHTAQnxg/etN0RaMDpehuJmZIjLMDVJ6DGIliRHGD6pODi1CXLQAN9GV0GSyB3G6yCuK05PkPQ==", + "license": "MIT" + }, "node_modules/thenify": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", diff --git a/package.json b/package.json index 6dd0de3..8d5b442 100644 --- a/package.json +++ b/package.json @@ -28,6 +28,8 @@ }, "type": "module", "dependencies": { - "svelte-parallax": "^0.6.0" + "linq": "^4.0.3", + "svelte-parallax": "^0.6.0", + "theme-change": "^2.5.0" } } diff --git a/src/lib/OpenBirchService.ts b/src/lib/OpenBirchService.ts index ecbee8b..7d60ed0 100644 --- a/src/lib/OpenBirchService.ts +++ b/src/lib/OpenBirchService.ts @@ -2,6 +2,7 @@ import { writable } from 'svelte/store'; // Adds window.runEval into typescript env declare function runEval(expression: string, stopAssignments?: boolean): any; +declare function resetOpenBirch(): any; const OpenBirchHistory: OpenBirchConsoleEntry[] = []; @@ -28,7 +29,16 @@ function createOpenBirchInstance(){ } catch (e) { return ''; } - }, // TODO: Replace with actual implimentation + }, + resetState: () => { + resetOpenBirch(); + }, + getHistory: (filter: ConsoleSender | undefined = undefined): OpenBirchConsoleEntry[] => { + if (filter == undefined) + return OpenBirchHistory; + + return OpenBirchHistory.filter(x=>x.sender == filter); + } } } @@ -44,7 +54,7 @@ class OpenBirchConsoleEntry { } } -enum ConsoleSender { +export enum ConsoleSender { User, System } \ No newline at end of file diff --git a/src/routes/+page.svelte b/src/routes/+page.svelte index 212c65a..8ba1d4e 100644 --- a/src/routes/+page.svelte +++ b/src/routes/+page.svelte @@ -4,6 +4,8 @@ import welcome_fallback from '$lib/images/svelte-welcome.png'; import differencialBackgroundVideo from '$lib/videos/DifferentialEquation.gif'; import "tailwindcss/tailwind.css"; + import ConsoleText from './console/ConsoleText.svelte'; + import { OpenBirch } from "$lib/OpenBirchService"; const sleep = (ms: number) => { return new Promise((resolve) => setTimeout(resolve, ms)); @@ -12,17 +14,46 @@ let isAutoTyping = true; let textField: HTMLInputElement; async function startTyping(){ - for (let charecter of "testing..."){ - if (!isAutoTyping) break; - textField.value += charecter; - await sleep(200); + for (var example of exampleInputs) { + for (let charecter of example){ + if (!isAutoTyping) break; + textField.value += charecter; + await sleep(200); + } + try {OpenBirch.sendCommand(textField.value);} catch (_) {} + resetFeild(); } } + const exampleInputs: readonly string[] = [ + "2+2", + "69*420+50", + "sin(2+4)", + "sqrt(9)", + "nroot(27, 3)", + "f(x):=2*x", + "f(5)", + "pi", + "e", + "myvar := 5", + "15 + myvar", + "myfunctionvar := f", + "myfunctionvar(10)", + "d/dx x", + "d/dx x^2", + "d/dx 69*x^2", + "d/dx sin(x)*x^2" + ]; + async function resetFeild() { textField.value = ""; } + async function onInputClicked() { + OpenBirch.resetState(); + window.location.href = "/console"; + } + import { onMount } from 'svelte'; import { Parallax, ParallaxLayer, StickyLayer } from 'svelte-parallax'; onMount(() => { @@ -50,23 +81,50 @@
-I love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love
+I love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love the colour of yellow and I also love
+