BlazorObservers 1.0.1

dotnet add package BlazorObservers --version 1.0.1                
NuGet\Install-Package BlazorObservers -Version 1.0.1                
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="BlazorObservers" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BlazorObservers --version 1.0.1                
#r "nuget: BlazorObservers, 1.0.1"                
#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 BlazorObservers as a Cake Addin
#addin nuget:?package=BlazorObservers&version=1.0.1

// Install BlazorObservers as a Cake Tool
#tool nuget:?package=BlazorObservers&version=1.0.1                

BlazorObservers

BlazorObservers is a set of Blazor wrappers around the JavaScript Observer functionality.

Currently only the ResizeObserver is supported.

Introduction

Blazor not support resize events. This means that usually, a complicated JSInterop will be required, which adds a lot of boilerplate code to the project.

This library attempts to prevent this issue, by providing a manager, which creates and deletes JavaScript ResizeObservers. This allows efficient and clean code to execute dotNET methods on element(s) resize.

Usage

First add the ResizeObserverService to the dependency injection.

using BlazorObservers.ObserverLibrary.DI;

...

builder.Services.AddResizeObserverService();

And add the using statements to the imports.razor

@using BlazorObservers.ObserverLibrary.JsModels
@using BlazorObservers.ObserverLibrary.Services
@using BlazorObservers.ObserverLibrary.Tasks

Then you can inject the ResizeObserverService into your razor component.

Now register an element with the OnAfterRenderAsync method, and make sure the registration is removed on disposal.


@inject ResizeObserverService ResizeService
@implements IAsyncDisposable

<div @ref="targetElement" style="width: 100%; height: 100%; background-color: green;"></div>

private ElementReference targetElement { get; set; }
private ObserverTask? taskReference;

protected override async Task OnAfterRenderAsync(bool firstRender)
{
    if (firstRender)
        taskReference = await ResizeService.RegisterObserver(
            async (entries) => Console.WriteLine("Hello resizable world"), 
            targetElement);
}

public async ValueTask DisposeAsync()
{
    if (taskReference is not null)
        await ResizeService.DeregisterObserver(taskReference);
}

When changing the size of (one of) the observed element(s) in your callback method, make sure to halt callback execution, as otherwise an infinite loop can appear, and crash your application.

protected override async Task OnAfterRenderAsync(bool firstRender)
{
    if (firstRender)
    {
        taskReference = await ResizeService.RegisterObserver(ObserverResizeEvent, TabBar);
    }
}

private async Task ObserverResizeEvent(JsResizeObserverEntry[] entries)
{
    if (taskReference is null) return;
    taskReference.HaltTaskTriggering();
    await MethodThatChangesTheElementSize();
    taskReference.ResumeTaskTriggering();
}

Future

Completed:

  • Make ResizeObserver callback parameters available
  • Auto-package
  • Add compatibility with element rerendering, so that the ResizeObserver stops observing the original element, and starts observing the newly rendered element.

Feature backlog:

  • Add ExecuteFinal option to HaltTaskTriggering, so that the last callback with the accurate size change is executed.
  • Add more observers, such as MutationObserver and IntersectionObserver
  • Unit testing
  • Performance analysis
Product Compatible and additional computed target framework versions.
.NET 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 was computed.  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 was computed.  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 (1)

Showing the top 1 popular GitHub repositories that depend on BlazorObservers:

Repository Stars
ScottPlot/ScottPlot
Interactive plotting library for .NET
Version Downloads Last updated
1.0.1 12,866 6/14/2022
1.0.0 204 6/14/2022

Tag update