diff options
Diffstat (limited to 'src/debug/Repl.tsx')
| -rw-r--r-- | src/debug/Repl.tsx | 63 | 
1 files changed, 63 insertions, 0 deletions
| diff --git a/src/debug/Repl.tsx b/src/debug/Repl.tsx new file mode 100644 index 000000000..c2db3bdcb --- /dev/null +++ b/src/debug/Repl.tsx @@ -0,0 +1,63 @@ +import * as React from 'react'; +import * as ReactDOM from 'react-dom'; +import { observer } from 'mobx-react'; +import { observable, computed } from 'mobx'; +import { CompileScript } from '../client/util/Scripting'; +import { makeInterface } from '../new_fields/Schema'; + +@observer +class Repl extends React.Component { +    @observable text: string = ""; + +    @observable executedCommands: { command: string, result: any }[] = []; + +    onChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => { +        this.text = e.target.value; +    } + +    onKeyDown = (e: React.KeyboardEvent) => { +        if (!e.ctrlKey && e.key === "Enter") { +            e.preventDefault(); +            const script = CompileScript(this.text, { +                addReturn: true, typecheck: false, +                params: { makeInterface: "any" } +            }); +            if (!script.compiled) { +                this.executedCommands.push({ command: this.text, result: "Compile Error" }); +            } else { +                const result = script.run({ makeInterface }); +                if (result.success) { +                    this.executedCommands.push({ command: this.text, result: result.result }); +                } else { +                    this.executedCommands.push({ command: this.text, result: result.error.message || result.error }); +                } +            } +            this.text = ""; +        } +    } + +    @computed +    get commands() { +        return this.executedCommands.map(command => { +            return ( +                <div style={{ marginTop: "5px" }}> +                    <p>{command.command}</p> +                    <pre>{JSON.stringify(command.result, null, 2)}</pre> +                </div> +            ); +        }); +    } + +    render() { +        return ( +            <div> +                <div style={{ verticalAlign: "bottom" }}> +                    {this.commands} +                </div> +                <textarea style={{ width: "100%", position: "absolute", bottom: "0px" }} value={this.text} onChange={this.onChange} onKeyDown={this.onKeyDown} /> +            </div> +        ); +    } +} + +ReactDOM.render(<Repl />, document.getElementById("root"));
\ No newline at end of file | 
