npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

crs-monaco-editor

v0.0.17

Published

vanilla webcomponent for using monaco editor

Downloads

7

Readme

CRS Monaco Editor

Introduction

This is a web component that encapsulates the monaco editor in a custom element for modular use.
This is a vanilla web component and is not extensive at all, i just creates a web component wrapper around monaco.

A small detail but a important one is that the component relies on es6 modules so please load the script using a module script. See the examples below for details.

Usage

<crs-monaco-editor id="editor"></crs-monaco-editor>
<script type="module" src="./path/crs-monaco-editor.js"></script>

Please note that this is a blank canvas. You can set the language attribute to a supported monaco language but there are no features enabled or disabled by default.

If you want to bring certain language features to the front you can write a separate component that modifies editor.

Extending the default behaviour

This component dispatches a custom event called "loaded" when it has loaded all it's required resources and is ready to be coded against.

  1. Create a custom element and give it a for attribute with the id of the crs-monaco-editor.
  2. On connected callback lookup the crs-monaco-editor and set a event listener for the "loaded" event.
  3. On the loaded event, commence with your add on code.
<schema-editor for="editor"></schema-editor>
<script type="module" src="./path/schema-editor.js"></script>

consider the following code as a sample loaded event handler

_loaded(event) {
    this.monaco = event.detail.monaco;
    this.editor = event.detail.editor;
    this.parent.removeEventListener("loaded", this._loadedHandler);

    this.parent.language = "json";
    this.parent.value = documentText.trim();
    this.monaco.languages.registerCompletionItemProvider('json', {
        provideCompletionItems: this._provideCompletionItemsHandler
    });
}

In the above example the parent element is the crs-monaco-editor initialised during the connected callback.
Note that the event's detail object sends back the monaco object and instance of the editor.

If you want to set the language, you can just set the language property on the crs-monaco-editor element.
To set the value / text on the editor, set the value property on the crs-monaco-editor.
If you want the value of the changed text, you can just read the value property again.
It will extract that from the monaco editor and pass it back to you.

Extensions

With this component there is also a sample extension in the extensions folder.

Too put them together you can just do the following.

<crs-monaco-editor id="editor"></crs-monaco-editor>
<schema-editor for="editor"></schema-editor>

<script type="module" src="./pathToCode/crs-monaco-editor.js"></script>
<script type="module" src="./pathToCode/extensions/schema-editor.js"></script>

Monaco not in node modules?

This component ships with two html files that it uses.
You can edit these to alter the behaviour as required.

Monaco was never written to play nice with es6 modules.
To make it play nice in this component, it is hosted in a iframe.
The html that gets loaded in that iframe is crs-monaco-editor-inner.html.
You can find this file along with the the components source file.
You can edit this file to your liking to fit your needs.

If you have moved your monaco source other than node_modules or want a different load strategy, go alter that file to your hears content.

Show and hide minimap

crs-monaco-editor has a attribute for you to affect the visibility of the minimap (bar on the right). If you want to hide the minimap you can set the show-minimap attribute to false.

<crs-monaco-editor id="editor" show-minimap="false"></crs-monaco-editor>

The minimap visibility is set when you set the value.
If you do not set the attribute it will show by default.

You can also initialize this by default in the crs-monaco-editor-inner.html like this:

window.editor = monaco.editor.create(document.getElementById('container'), {
    minimap: {
        enabled: true
    }
});