No Description

Henning Dieterichs 24f57fec21 Adds .gitattributes to ensure all source files are stored as LF in git. 3 years ago
.github 259196bc1e Merge branch 'microsoft:main' into bugfix-workflow-publish 3 years ago
.husky e8dabe034a Add pre-commit hooks 3 years ago
.vscode 41ded74b37 Go back to using `mocha` for unit tests 3 years ago
build 1134d5e82b ESM: Do not append the `.js` suffix to imports if it's already there 3 years ago
docs 903a92c7bb Update links 3 years ago
samples 3e1050ffd6 Merge pull request #2896 from microsoft/dependabot/npm_and_yarn/samples/browser-esm-parcel/follow-redirects-1.14.7 3 years ago
src 743073476a Update swift.ts 3 years ago
test 75af762db9 Fix paths when running from `file://` 3 years ago
webpack-plugin d735c42561 Bump nanoid from 3.1.30 to 3.2.0 in /webpack-plugin 3 years ago
website 1134d5e82b ESM: Do not append the `.js` suffix to imports if it's already there 3 years ago
.gitattributes 24f57fec21 Adds .gitattributes to ensure all source files are stored as LF in git. 3 years ago
.gitignore 91c9c0cec3 Ignore generated files 3 years ago
.mocharc.json 7e766abe78 Adjust smoke test which also uses mocha 3 years ago
.prettierignore bbaa2d846d Do not check in generated samples file 3 years ago
.prettierrc 84bdc31efe run `prettier` 3 years ago
CHANGELOG.md 3159d3d6c9 Adopt latest `monaco-editor-core` 3 years ago
CONTRIBUTING.md 9fac3918b2 Adopt the new `editor/contrib` layering rules in the esm metadata generation 3 years ago
LICENSE.txt 67a240a269 Rename LICENSE file 3 years ago
MAINTAINING.md 3afc60f1ac Add changelog entry for 0.31.0 3 years ago
README.md 903a92c7bb Update links 3 years ago
SECURITY.md 84bdc31efe run `prettier` 3 years ago
ThirdPartyNotices.txt 903a92c7bb Update links 3 years ago
editor.code-workspace c3ac455fd2 Remove unused functions 3 years ago
gulpfile.js 207f0cf42a Move website task out of `gulp` 3 years ago
metadata.js 8f2bc4ac98 Add support to run from source using `tsc -w` 3 years ago
package-lock.json 1134d5e82b ESM: Do not append the `.js` suffix to imports if it's already there 3 years ago
package.json 1134d5e82b ESM: Do not append the `.js` suffix to imports if it's already there 3 years ago

README.md

Monaco Editor

Build Status

The Monaco Editor is the code editor which powers VS Code, with the features better described here.

Please note that this repository contains no source code for the code editor, it only contains the scripts to package everything together and ship the monaco-editor npm module.

image

Try it out

Try the editor out on our website.

Installing

$ npm install monaco-editor

You will get:

  • inside esm: ESM version of the editor (compatible with e.g. webpack)
  • inside dev: AMD bundled, not minified
  • inside min: AMD bundled, and minified
  • inside min-maps: source maps for min
  • monaco.d.ts: this specifies the API of the editor (this is what is actually versioned, everything else is considered private and might break with any release).

It is recommended to develop against the dev version, and in production to use the min version.

Documentation

Issues

Create issues in this repository for anything related to the Monaco Editor. Always mention the version of the editor when creating issues and the browser you're having trouble in. Please search for existing issues to avoid duplicates.

FAQ

What is the relationship between VS Code and the Monaco Editor?

The Monaco Editor is generated straight from VS Code's sources with some shims around services the code needs to make it run in a web browser outside of its home.

What is the relationship between VS Code's version and the Monaco Editor's version?

None. The Monaco Editor is a library and it reflects directly the source code.

I've written an extension for VS Code, will it work on the Monaco Editor in a browser?

No.

Note: If the extension is fully based on the LSP and if the language server is authored in JavaScript, then it would be possible.

Why all these web workers and why should I care?

Language services create web workers to compute heavy stuff outside of the UI thread. They cost hardly anything in terms of resource overhead and you shouldn't worry too much about them, as long as you get them to work (see above the cross-domain case).

What is this loader.js? Can I use require.js?

It is an AMD loader that we use in VS Code. Yes.

I see the warning "Could not create web worker". What should I do?

HTML5 does not allow pages loaded on file:// to create web workers. Please load the editor with a web server on http:// or https:// schemes.

Is the editor supported in mobile browsers or mobile web app frameworks?

No.

Why doesn't the editor support TextMate grammars?

What about IE 11 support?

  • The Monaco Editor no longer supports IE 11. The last version that was tested on IE 11 is 0.18.1.

Development setup

Please see CONTRIBUTING

Code of Conduct

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

License

Licensed under the MIT License.