BlazorMonaco 3.3.0

dotnet add package BlazorMonaco --version 3.3.0                
NuGet\Install-Package BlazorMonaco -Version 3.3.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="BlazorMonaco" Version="3.3.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BlazorMonaco --version 3.3.0                
#r "nuget: BlazorMonaco, 3.3.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install BlazorMonaco as a Cake Addin
#addin nuget:?package=BlazorMonaco&version=3.3.0

// Install BlazorMonaco as a Cake Tool
#tool nuget:?package=BlazorMonaco&version=3.3.0                

BlazorMonaco

Nuget Nuget MonacoEditor License-MIT

<a href="#"> <img src="https://raw.githubusercontent.com/serdarciplak/BlazorMonaco/master/BlazorMonaco/icon.png" align="right" height="120" style="padding-left:20px;" /> </a>

Blazor component for Microsoft Monaco Editor which powers Visual Studio Code.

Most of the main Monaco Editor feature set is supported with some less-frequently used features currently missing. Any contributions, comments or suggestions are greatly welcome. Please feel free to contact me at x.com/serdarciplak or via GitHub.

The current BlazorMonaco version :

  • Uses Monaco Editor v0.52.2
  • Supports netstandard2.0, net5.0, net6.0, net7.0, net8.0 and net9.0

Demo

You can see a working sample WebAssembly app here.

Installation

  • Add the NuGet package to your Blazor project.

    dotnet add package BlazorMonaco
    // or
    Install-Package BlazorMonaco
    
  • Add the script tags below to the end of your html body tag. Note that they must be placed before the Blazor script tag (blazor.webassembly.js, blazor.server.js or blazor.web.js).

    <script src="_content/BlazorMonaco/jsInterop.js"></script>
    <script src="_content/BlazorMonaco/lib/monaco-editor/min/vs/loader.js"></script>
    <script src="_content/BlazorMonaco/lib/monaco-editor/min/vs/editor/editor.main.js"></script>
    
  • Everything resides in three namespaces. You can add the following using directives to your root _Imports.razor file, or any other place you may need them.

    @using BlazorMonaco
    @using BlazorMonaco.Editor
    @using BlazorMonaco.Languages
    
  • Add a StandaloneCodeEditor or a StandaloneDiffEditor component in your razor file and you'll see the editor rendered with the default options.

    <StandaloneCodeEditor />
    
    <StandaloneDiffEditor />
    

Note: If you have any issues like the editor not being visible or not initializing correctly, please check the troubleshooting section below.

Usage

Providing initial options

To customize your editor's initial options, set the ConstructionOptions parameter and provide a method that returns a StandaloneEditorConstructionOptions.

<StandaloneCodeEditor Id="my-code-editor" ConstructionOptions="EditorConstructionOptions" />

@code {
    private StandaloneEditorConstructionOptions EditorConstructionOptions(StandaloneCodeEditor editor)
    {
        return new StandaloneEditorConstructionOptions
        {
            AutomaticLayout = true,
            Language = "javascript",
            Value = "function xyz() {\n" +
                    "   console.log(\"Hello world!\");\n" +
                    "}"
        };
    }
}

Listening to editor events

You can subscribe to editor events (e.g. OnDidKeyUp or OnDidPaste) via the editor event parameters.

<StandaloneCodeEditor Id="my-code-editor" OnDidChangeCursorPosition="EditorDidChangeCursorPosition" />

@code {
    private void EditorDidChangeCursorPosition(CursorPositionChangedEvent eventArgs)
    {
        Console.WriteLine("EditorDidChangeCursorPosition");
    }
}

Accessing a diff editor's inner editors and events

StandaloneDiffEditor provides two properties named OriginalEditor and ModifiedEditor for accessing the inner editor instances. You can use them like any other StandaloneCodeEditor instance.

You can register to inner editors' events using the helper event parameters of the main StandaloneDiffEditor instance.

<StandaloneDiffEditor @ref="_diffEditor" Id="my-diff-editor" OnKeyUpOriginal="OnKeyUpOriginal" OnKeyUpModified="OnKeyUpModified" />

@code {
    private StandaloneDiffEditor _diffEditor;

    private void OnKeyUpOriginal(KeyboardEvent keyboardEvent)
    {
        StandaloneCodeEditor originalEditor = _diffEditor.OriginalEditor;
        Console.WriteLine("OnKeyUpOriginal : " + keyboardEvent.Code);
    }

    private void OnKeyUpModified(KeyboardEvent keyboardEvent)
    {
        StandaloneCodeEditor modifiedEditor = _diffEditor.ModifiedEditor;
        Console.WriteLine("OnKeyUpModified : " + keyboardEvent.Code);
    }
}

Css styling

There are 3 css selectors you can use to customize the css styles for your editors.

  • All editor instances are contained in a div element that has a css class of monaco-editor-container.
  • The Id value you set for your editor instance is also set as the id of its container div element.
  • If you set your editor's CssClass property, that value is added to the class attribute of its container div element.

That means, the razor component below;

<StandaloneCodeEditor Id="my-editor-id" CssClass="my-editor-class" />

is rendered with the html below;

<div id="my-editor-id" class="monaco-editor-container my-editor-class">
    ...
</div>

So, you can use css selectors like below to select any element in an editor and customize its styling.

#my-editor-id { /* applies to a specific editor instance */
    height: 100px;
}

.my-editor-class { /* applies to all editor instances with this class */
    height: 100px;
}

.monaco-editor-container { /* applies to all editor instances */
    height: 100px;
}

Global Methods

Monaco Editor JavaScript library defines some methods in the global scope. As C# does not allow global methods, BlazorMonaco groups those methods in two static classes named BlazorMonaco.Editor.Global and BlazorMonaco.Language.Global. If you need to use a Monaco Editor method in the global scope, check where in the JavaScript library that method is, and search for it in the corresponding Global class.

For example, you can use the SetTheme method like below.

await BlazorMonaco.Editor.Global.SetTheme(jsRuntime, "my-custom-theme");

Using a custom Monaco Editor installation

If you've made changes to Monaco Editor JS library, and need to use this edited version instead of the unmodified version embedded in BlazorMonaco, you can modify the script tags like below.

<script src="_content/BlazorMonaco/jsInterop.js"></script>
<script>var require = { paths: { vs: 'my-path/monaco-editor/min/vs' } };</script>
<script src="my-path/monaco-editor/min/vs/loader.js"></script>
<script src="my-path/monaco-editor/min/vs/editor/editor.main.js"></script>

Troubleshooting

  • Q: I have added a StandaloneCodeEditor as described above, but it's not loading.

    A: Most possibly, the editor is actually loading but you cannot see it because it has a height of 0. How a DOM element's height can be set depends on its parent elements and their styling. So, BlazorMonaco cannot internally manage the height of the editor instances. If you don't set an editor's height, it may be invisible as it has a height of 0px. Please add a CSS style to set your editor's height according to where it's placed.

    #my-editor-id {
        height: 100px;
    }
    
  • Q: The editor does not initialize correctly in my Blazor web app.

    A: To be able to work with the interactive MonacoEditor JS library, BlazorMonaco requires an interactive render mode. If you place the editor instance in a page that uses static server-side rendering (static SSR), the editor instance cannot initialize and work.

    You can set an interactive render mode globally at the app level,

    
    <Routes @rendermode="InteractiveServer" />
    

    only for a specific page,

    
    @page "/editor-page"
    @rendermode InteractiveServer
    
    <StandaloneCodeEditor />
    

    or only for a component that wraps the editor instance.

    
    @rendermode InteractiveServer
    
    <StandaloneCodeEditor />
    
  • Q: The editor works OK the first time it's displayed. But it is broken (as if its css style is incorrect), if the user navigates to another page and returns back to the editor's page.

    A: Please check that the page that contains the editor instance is not opened with Blazor enhanced navigation. Enhanced navigation undos dynamic changes made to the DOM by MonacoEditor JS library and breaks the editor. You need to disable enhanced navigation for pages that contain an editor.

    You can set the data-enhance-nav attribute of your links to false,

    <a href="editor-page" data-enhance-nav="false">Editor Page</a>
    

    set forceLoad parameter in your NavigateTo() calls to true,

    Navigation.NavigateTo("editor-page", true);
    

    or use the Blazor docs here to see all methods for disabling enhanced navigation.

Documentation

As BlazorMonaco is just a bridge between JavaScript and Blazor, you can use Monaco Editor's documentation.

Migration Guide

After a major version update (like from v2.x to v3.x), you may need to make some changes in your integration. Please see the MIGRATE.md file for details.

Changelog

You can view the history and the changes in the CHANGELOG.md file.

License

MIT, see the LICENSE file for details.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (11)

Showing the top 5 NuGet packages that depend on BlazorMonaco:

Package Downloads
PanoramicData.Blazor

Blazor components

Elsa.Studio.Shared

Elsa Studio shared services and components.

Strem.Flows.Default

Package Description

BlazorMonacoYaml

Monaco Yaml editor for Blazor is a Yaml style configuration setup for Blazor Monaco, with which you can easily setup YAML Editors and YAML Diffing Editors.

TableViewer.MudBlazor

Package Description

GitHub repositories (12)

Showing the top 5 popular GitHub repositories that depend on BlazorMonaco:

Repository Stars
json-everything/json-everything
System.Text.Json-based support for all of your JSON needs.
DragoQCC/HardHatC2
A C# Command & Control framework
revenz/FileFlows
FileFlows is a file processing application that can execute actions against a file in a tree flow structure.
flyingpie/windows-terminal-quake
Enable Quake-style dropdown for (almost) any application.
CervantesSec/cervantes
Cervantes is an open-source, collaborative platform designed specifically for pentesters and red teams. It serves as a comprehensive management tool, streamlining the organization of projects, clients, vulnerabilities, and reports in a single, centralized location.
Version Downloads Last updated
3.3.0 973 12/26/2024
3.2.0 277,976 2/25/2024
3.1.0 185,704 8/27/2023
3.0.0 198,431 1/23/2023
2.1.0 352,673 4/12/2021
2.0.0 8,066 2/21/2021
1.6.1 4,654 2/6/2021
1.6.0 6,580 12/6/2020
1.5.0 9,168 11/1/2020
1.4.0 5,993 7/19/2020
1.3.1 8,447 6/15/2020
1.3.0 1,374 6/7/2020
1.2.2 1,724 5/22/2020
1.2.1 387 5/5/2020
1.2.0 367 5/2/2020
1.1.0 351 4/26/2020
1.0.3 335 4/24/2020
1.0.2 1,273 4/23/2020
1.0.1 1,773 4/23/2020