MT.Blazor.ConnectivityDetection
1.0.0
dotnet add package MT.Blazor.ConnectivityDetection --version 1.0.0
NuGet\Install-Package MT.Blazor.ConnectivityDetection -Version 1.0.0
<PackageReference Include="MT.Blazor.ConnectivityDetection" Version="1.0.0" />
paket add MT.Blazor.ConnectivityDetection --version 1.0.0
#r "nuget: MT.Blazor.ConnectivityDetection, 1.0.0"
// Install MT.Blazor.ConnectivityDetection as a Cake Addin #addin nuget:?package=MT.Blazor.ConnectivityDetection&version=1.0.0 // Install MT.Blazor.ConnectivityDetection as a Cake Tool #tool nuget:?package=MT.Blazor.ConnectivityDetection&version=1.0.0
MT.Blazor.ConnectivityDetection
Blazor WASM component library for network connectivity detection
Installing
You can install from Nuget using the following command:
Install-Package MT.Blazor.ConnectivityDetection
Or via the Visual Studio package manger.
Basic Usage
Start by add the following using statement to your root _Imports.razor
.
@using MT.Blazor.ConnectivityDetection
Then add the connectivity state provider in the App.razor
root component around the Router
.
<CascadingConnectivityState>
<Router AppAssembly="@typeof(Program).Assembly">
<Found Context="routeData">
<RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)" />
</Found>
<NotFound>
<p>Sorry, there's nothing at this address.</p>
</NotFound>
</Router>
</CascadingConnectivityState>
The CascadingConnectivityState
component subscribes to and starts the network connectivity detection by the IConnectivityStateProvider
upon initialization
and notifies nested components of change in network connectivity with ConnectivityState
.
The IConnectivityStateProvider
is the underlying service that subscribes to the javascript based network connectivity detection and provides ConnectivityState
to subscribers.
Registering Connectivity Detection
Register and configure connectivity detection in IServiceCollection
in Program.cs
builder.Services.AddConnectivityDetection();
By default, network connectivity state is determine with the browser's navigator.onLine
information and quality of connection with the Network Information API.
Since the Network Information API is experimental and has varying browser compatibility, it is highly recommended to configure a HTTP ping check with the ConnectivityOptions
in the
AddConnectivityDetection
method.
builder.Services.AddConnectivityDetection(options =>
{
options.PingUrl = "/api/ping";
options.PingInterval = 1000;
});
These options will start an HTTP based connectivity check in addition to the Network Information API detection every second. You can configure any API end point to use as a ping check, however, it's best to host the end point in the server for an ASP.NET Core hosted Blazor WebAssembly application to have the connectivity state be based on latency between with the hosting server application.
Latency
When performing ping checks, latency is calculated in milliseconds to completion of a successfully HTTP GET to the end point.
With the Network Information API based connectivity detection, due to browser compatibility and the experimental nature of the API, the latency value is a static, representative value in milliseconds as follows:
effectiveType
value4g
anddownlink
value of10
for a fast connection is represented as50ms
downlink
value greater than or equal to5
is represented as500ms
and1000ms
otherwise
effectiveType
value3g
is represented as500ms
and1000ms
otherwise
When a ping check is configured, then an ad-hoc ping check is performed when the latency measurement as described previously is greater than 50ms
as an accurate verification.
Connectivity Status
The ConnectivityState
value that cascades from the CascadingConnectivityState
as provided by the IConnectivityStateProvider
conveys the connectivity check type, latency, and
status to the client application as ConnectivityStatus
enum value of Offline
, Online
, or Slow
.
The thresholds for the the statuses as as follows:
Offline
whennavigator.onLine
isfalse
or the ping check failsOnline
when latency value is less than500ms
otherwiseSlow
- The
500ms
threshold currently is not configurable
- The
Any service can retrieve the current ConnectivityState
by injecting the IConnectivityStateProvider
as a dependency and query the current ConnectivityState
by calling
the IConnectivityStateProvider.GetConnectivityStateAsync()
method or by subscribing to the IConnectivityStateProvider.ConnectivityStateChanged
event.
Change Log
- 0.0.0 Pre-release
- 1.0.0 Initial release
Links
Product | Versions 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. net9.0 was computed. 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. |
-
net6.0
- Ardalis.GuardClauses (>= 4.0.1)
- Microsoft.AspNetCore.Components.Web (>= 6.0.4)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.