Added speculative/preview to commands

This commit is contained in:
BOTAlex 2024-07-31 04:37:29 +02:00
parent 184f2617cd
commit 46c06773cd
3 changed files with 36 additions and 13 deletions

View File

@ -1,7 +1,7 @@
import { writable } from 'svelte/store'; import { writable } from 'svelte/store';
// Adds window.runEval into typescript env // Adds window.runEval into typescript env
declare function runEval(expression: string): any; declare function runEval(expression: string, stopAssignments?: boolean): any;
const OpenBirchHistory: OpenBirchConsoleEntry[] = []; const OpenBirchHistory: OpenBirchConsoleEntry[] = [];
@ -21,7 +21,14 @@ function createOpenBirchInstance(){
set(OpenBirchHistory); // Publishes changes to subscribers set(OpenBirchHistory); // Publishes changes to subscribers
//console.log(OpenBirchHistory); //console.log(OpenBirchHistory);
} },
speculateCommand: (command: string): string => {
try {
return runEval(command, true);
} catch (e) {
return '';
}
}, // TODO: Replace with actual implimentation
} }
} }

View File

@ -12,6 +12,12 @@
if (event.key === 'Enter') { if (event.key === 'Enter') {
pushCommand(); pushCommand();
} }
if (inputField.value == '' && event.key !== 'Enter') return;
setTimeout(() => {
updatePreviewCommand();
}, 25);
} }
// Locally start sending command // Locally start sending command
@ -19,6 +25,11 @@
OpenBirch.sendCommand(inputField.value) OpenBirch.sendCommand(inputField.value)
inputField.value = ''; inputField.value = '';
} }
let previewText: HTMLElement;
function updatePreviewCommand(){
previewText.innerHTML = OpenBirch.speculateCommand(inputField.value);
}
</script> </script>
<div class="consoleContainer p-4"> <div class="consoleContainer p-4">
@ -37,16 +48,21 @@
</div> </div>
<div class="pt-4 join"> <div class="pt-4 join">
<div class="input join-item input-bordered flex grow items-center gap-2"> <div class="input join-item input-bordered flex items-center grow gap-2 h-20" style="cursor: text;">
<svg <div class="w-full">
xmlns="http://www.w3.org/2000/svg" <div class="flex">
viewBox="0 0 24 24" <svg
class="h-8 w-8 opacity-70 block m-auto fill-primary"> xmlns="http://www.w3.org/2000/svg"
<path d="M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"/> viewBox="0 0 24 24"
</svg> class="h-8 w-8 opacity-70 block m-auto fill-primary">
<input autofocus type="text" class="grow text-primary" placeholder="" bind:this={inputField} on:keydown={handleKeydown} /> <path d="M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"/>
</svg>
<input autofocus type="text" class="text-primary grow" placeholder="" bind:this={inputField} on:keydown={handleKeydown} />
</div>
<div class="text-accent opacity-50 italic" bind:this={previewText} style="line-height: 1rem; height: 0;"></div>
</div>
</div> </div>
<button class="btn join-item btn-secondary" on:click={pushCommand}>Execute</button> <button class="btn join-item btn-secondary h-20" on:click={pushCommand}>Execute</button>
</div> </div>
</div> </div>

View File

@ -8,7 +8,7 @@ function str2C(s) {
} }
window.runEval = function (inputText, stopAssignments = false) { window.runEval = function (inputText, stopAssignments = false) {
console.log("input: " + inputText); if (!stopAssignments) console.log("input: " + inputText);
var inputPtr = str2C(inputText); var inputPtr = str2C(inputText);
var resultPointer = Module._eval(inputPtr, stopAssignments); var resultPointer = Module._eval(inputPtr, stopAssignments);
@ -25,7 +25,7 @@ window.runEval = function (inputText, stopAssignments = false) {
i++; i++;
} }
} }
console.log("Result from eval:", resultString); if (!stopAssignments) console.log("Result from eval:", resultString);
// Free allocated memory // Free allocated memory
_free(resultPointer); _free(resultPointer);