Blazor.Editor 2.0.4

There is a newer version of this package available.
See the version list below for details.
dotnet add package Blazor.Editor --version 2.0.4                
NuGet\Install-Package Blazor.Editor -Version 2.0.4                
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="Blazor.Editor" Version="2.0.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Blazor.Editor --version 2.0.4                
#r "nuget: Blazor.Editor, 2.0.4"                
#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 Blazor.Editor as a Cake Addin
#addin nuget:?package=Blazor.Editor&version=2.0.4

// Install Blazor.Editor as a Cake Tool
#tool nuget:?package=Blazor.Editor&version=2.0.4                

BlazorEditor

It is a quilljs based richtext editor.

it's accept ReadOnly, Placeholder, Theme, Height and endpoint url to insert image etc

Very simple to use add nuget package and use it.

In this version 2.0.3 has update ui and core functions improvements like image search, resize, align etc and also package size optimized.

New Features in this version:
Image resize can be done from top and bottom
Compact resize toolbar
Image drop enable
Dropped image inserted into editor as base64 string
Getter and Setter by quilljs Delta object

How to add package into project

dotnet add package Blazor.Editor --version 2.0.3

<div> @GalleryUrl is endpoint of your server's image gallery to show image list, if api endpoint is not provided then url image link is still working@ <Editor @ref="@_quillNative" GalleryUrl="/api/images/gallery" /> </div>

<div> <button class="btn btn-primary" @onclick="SetHTMLAsync">Set HTML</button> <button class="btn btn-primary" @onclick="GetHTMLAsync">Get HTML</button> <button class="btn btn-primary" @onclick="SetContentAsync">Set Contents</button> <button class="btn btn-primary" @onclick="GetContentAsync">Get Contents</button> </div>

<div> @_quillContent </div>

@code { private string? _quillContent; private Editor? _quillNative;

public async Task SetHTMLAsync()
{
	string img = "<p><img src='https://images.stockcake.com/public/5/0/2/502bbf64-d559-4efe-bba5-59ef7ffad5a8/toddler-baking-cookies-stockcake.jpg' /></p>";
	await _quillNative!.SetHTMLAsync(img);
	StateHasChanged();
}
public async Task GetHTMLAsync()
{
	_quillContent = await _quillNative!.GetHTMLAsync();
	StateHasChanged();
}
public async Task SetContentAsync()
{
	var image = new Dictionary<string, object>()
	{
	    {
	        "image", new ImageFile(){
	            Src = "https://img.freepik.com/free-photo/woman-black-shirt-pointing-left-showing-her-emotions_144627-60740.jpg?w=1800&t=st=1726579146~exp=1726579746~hmac=3e36f98f85bdf588086750ae11e6d218f846b9f9e74ba0418bd1c92175ad09c3",
	            Alt = "Image In Editor"
	        }
	    }
	};

	var image2 = new Dictionary<string, object>()
	{
	    {
	        "image", new ImageFile(){
	            Src = "...",
	            Alt = "Image In Editor"
	        }
	    }
	};

	var ops = new List<Operation>
    {
        new() { Attributes = new() { { "align", "center" } }, Insert = "Hello, World!\n" },
        new() { Insert = "This is first line\n", Attributes = new() { { "bold", true } } },
        new() { Insert = "This is second line\n" },
        new() { Insert= image},
        new() { Insert= "\n},
        new() { Insert= image1},
        new() { Insert = "\n" }
    };

    var delta = new Delta(ops);
    await _quillNative!.SetContentAsync(delta);
    StateHasChanged();
}
public async Task GetContentAsync()
{
    _quillContent = await _quillNative!.GetContentAsync();
    StateHasChanged();
}

}


### Editor

![Editor](https://raw.githubusercontent.com/ray-vinod/BlogApp/refs/heads/image-drop-re/Blog/wwwroot/readmeImages/editor.jpg?token=GHSAT0AAAAAACXYVYAAPQCHCEJXCSRPYOHQZXOU3SQ)

### Image selection

![Image selection](https://raw.githubusercontent.com/ray-vinod/BlogApp/refs/heads/image-drop-re/Blog/wwwroot/readmeImages/image-choosing.jpg?token=GHSAT0AAAAAACXYVYAAL3HZTZIO7QG63PN4ZXOU4EQ)

### Image into editor

![Inserted image](https://raw.githubusercontent.com/ray-vinod/BlogApp/refs/heads/image-drop-re/Blog/wwwroot/readmeImages/image-in-editor.jpg?token=GHSAT0AAAAAACXYVYAAGGCH7BGNAN5V6Y2UZXOU4YQ)

### Resize and Format options

![Resize and Format](https://raw.githubusercontent.com/ray-vinod/BlogApp/refs/heads/image-drop-re/Blog/wwwroot/readmeImages/resize-options.jpg?token=GHSAT0AAAAAACXYVYAAHXYHEBTCH6WXBU7SZXOU5JA)

### Quilljs Delta Object

![Delta Object](https://raw.githubusercontent.com/ray-vinod/BlogApp/refs/heads/image-drop-re/Blog/wwwroot/readmeImages/delta-object.jpg?token=GHSAT0AAAAAACXYVYAAE63OOQH57TZZVWBQZXOU5XA)
Product Compatible and additional computed target framework versions.
.NET 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.6 91 9/23/2024
2.0.5 86 9/21/2024
2.0.4 132 9/21/2024
2.0.3 145 9/21/2024
2.0.2 107 9/7/2024
2.0.1 110 9/5/2024
2.0.0 104 9/4/2024
1.0.4 102 9/1/2024
1.0.3 104 9/1/2024
1.0.2 95 8/30/2024
1.0.1 97 8/30/2024
1.0.0 154 8/30/2024