You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The Monaco Editor is a rich code editor, ported from Microsoft's VS Code base, written in Typescript, designed to be run from a web browser. However, it currently only supports AMD/ESM loading techniques, which makes it a challenge to use within a React application that was created and maintained with create-react-app. Most efforts require you to eject your project and modify the default webpack configuration. This project, like SurenAt93's project, aims to avoid this complexity by dynamically loading the Monaco scripts by inject some require code via script tag and using the window.monaco global space it creates.
Installation
yarn add @memsetzero/react-monaco-editor
# or
npm i @memsetzero/react-monaco-editor
In order to load the scripts a single time and allow for any number of editors to gain access to the monaco environment, I've created a MonacoProvider component, which should be near the top-level of your App and wrap any other Editor components, so they can obtain the Monaco environment via React Context.
Controlled vs Uncontrolled
Components/Props
MonacoProvider
Name
Type
Default
Description
theme
enum: 'vs-light' | 'vs-dark'
'vs-light'
Theme to be used for the Monaco environment.
modelLanguages
array
[]
Sets an array of languages, used by models.
modelMarkers
array
[]
Sets an array of markers, used by models.
baseUrl
string
The CDN base url to fetch Monaco editor scripts.
loaderUrl
string
The CDN url for loading the Monaco editor scripts.