forked from nonsensical-dev/zenyx-engine
27 lines
680 B
JavaScript
27 lines
680 B
JavaScript
![]() |
import React, { useState } from "react";
|
||
|
|
||
|
import Editor from "@monaco-editor/react";
|
||
|
|
||
|
const CodeEditorWindow = ({ onChange, language, code, theme }) => {
|
||
|
const [value, setValue] = useState(code || "");
|
||
|
|
||
|
const handleEditorChange = (value) => {
|
||
|
setValue(value);
|
||
|
onChange("code", value);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<div className="overlay rounded-md overflow-hidden w-full h-full shadow-4xl">
|
||
|
<Editor
|
||
|
height="85vh"
|
||
|
width={`100%`}
|
||
|
language={language || "javascript"}
|
||
|
value={value}
|
||
|
theme={theme}
|
||
|
defaultValue="// some comment"
|
||
|
onChange={handleEditorChange}
|
||
|
/>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
export default CodeEditorWindow;
|