BlazorMonaco 3.3.0
dotnet add package BlazorMonaco --version 3.3.0
NuGet\Install-Package BlazorMonaco -Version 3.3.0
<PackageReference Include="BlazorMonaco" Version="3.3.0" />
paket add BlazorMonaco --version 3.3.0
#r "nuget: BlazorMonaco, 3.3.0"
// 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
<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
andnet9.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
orblazor.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 aStandaloneDiffEditor
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 ofmonaco-editor-container
. - The
Id
value you set for your editor instance is also set as the id of its containerdiv
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 tofalse
,<a href="editor-page" data-enhance-nav="false">Editor Page</a>
set
forceLoad
parameter in yourNavigateTo()
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 | Versions 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. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.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. |
-
.NETStandard 2.0
- Microsoft.AspNetCore.Components (>= 3.1.10)
- Microsoft.AspNetCore.Components.Web (>= 3.1.10)
-
net5.0
- Microsoft.AspNetCore.Components (>= 5.0.0)
- Microsoft.AspNetCore.Components.Web (>= 5.0.0)
-
net6.0
- Microsoft.AspNetCore.Components (>= 6.0.25)
- Microsoft.AspNetCore.Components.Web (>= 6.0.25)
-
net7.0
- Microsoft.AspNetCore.Components (>= 7.0.14)
- Microsoft.AspNetCore.Components.Web (>= 7.0.14)
-
net8.0
- Microsoft.AspNetCore.Components (>= 8.0.0)
- Microsoft.AspNetCore.Components.Web (>= 8.0.0)
-
net9.0
- Microsoft.AspNetCore.Components (>= 9.0.0)
- Microsoft.AspNetCore.Components.Web (>= 9.0.0)
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 | 5,618 | 12/26/2024 |
3.2.0 | 293,760 | 2/25/2024 |
3.1.0 | 187,780 | 8/27/2023 |
3.0.0 | 199,289 | 1/23/2023 |
2.1.0 | 354,442 | 4/12/2021 |
2.0.0 | 8,084 | 2/21/2021 |
1.6.1 | 4,665 | 2/6/2021 |
1.6.0 | 6,594 | 12/6/2020 |
1.5.0 | 9,184 | 11/1/2020 |
1.4.0 | 6,003 | 7/19/2020 |
1.3.1 | 8,451 | 6/15/2020 |
1.3.0 | 1,378 | 6/7/2020 |
1.2.2 | 1,728 | 5/22/2020 |
1.2.1 | 391 | 5/5/2020 |
1.2.0 | 372 | 5/2/2020 |
1.1.0 | 355 | 4/26/2020 |
1.0.3 | 339 | 4/24/2020 |
1.0.2 | 1,277 | 4/23/2020 |
1.0.1 | 1,808 | 4/23/2020 |
See the change log for release notes:
https://github.com/serdarciplak/BlazorMonaco/blob/master/CHANGELOG.md