Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lostbeard/spawndev.blazorjs.socketio
Socket.IO bidirectional and low-latency communication for every platform, in Blazor WebAssembly
https://github.com/lostbeard/spawndev.blazorjs.socketio
blazor blazor-webassembly dotnet webbrowser websocket
Last synced: 3 months ago
JSON representation
Socket.IO bidirectional and low-latency communication for every platform, in Blazor WebAssembly
- Host: GitHub
- URL: https://github.com/lostbeard/spawndev.blazorjs.socketio
- Owner: LostBeard
- License: mit
- Created: 2024-07-09T12:49:55.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-08-06T18:08:01.000Z (6 months ago)
- Last Synced: 2024-11-07T11:05:16.306Z (3 months ago)
- Topics: blazor, blazor-webassembly, dotnet, webbrowser, websocket
- Language: C#
- Homepage:
- Size: 188 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# SpawnDev.BlazorJS.SocketIO
Bidirectional and low-latency communication for every platform.[![NuGet version](https://badge.fury.io/nu/SpawnDev.BlazorJS.SocketIO.svg?label=SpawnDev.BlazorJS.SocketIO)](https://www.nuget.org/packages/SpawnDev.BlazorJS.SocketIO)
**SpawnDev.BlazorJS.SocketIO** brings the amazing [socket.io](https://github.com/socketio/socket.io) library to Blazor WebAssembly.
**SpawnDev.BlazorJS.SocketIO** uses [SpawnDev.BlazorJS](https://github.com/LostBeard/SpawnDev.BlazorJS) for Javascript interop allowing strongly typed, full access to the [socket.io](https://github.com/socket.io/socket.io) Javascript library.
## Setup
**Create a new Blazor WebAssembly Standalone App**
In the folder you created for your new project:
```dotnet
dotnet new blazorwasm
```**Add the Nuget package**
```dotnet
dotnet add package SpawnDev.BlazorJS.SocketIO
```**Add BlazorJSRuntime service**
Add to `Program.cs`
```cs
builder.Services.AddBlazorJSRuntime();
```**Add SocketIO Javascript Library**
Add to `index.html`
```html```
(Alternatively `await Socket.Init()` can be used in C# to load the SocketIO library at runtime)**Create a Socket**
```cs
var socket = new Socket(socketIoServerUrl);
```## Shared Counter example from repo
In this example, when any user changes the counter value by clicking the button all users see the value change.Program.cs
```cs
using Microsoft.AspNetCore.Components.Web;
using Microsoft.AspNetCore.Components.WebAssembly.Hosting;
using SpawnDev.BlazorJS;
using SpawnDev.BlazorJS.SocketIO;
using SpawnDev.BlazorJS.SocketIO.Demo;var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add("#app");
builder.RootComponents.Add("head::after");// init SpawnDev.BlazorJS.BlazorJSRuntime service
builder.Services.AddBlazorJSRuntime();// Load the Socket.IO Javascript library. Can be loaded using a tag in the index.html instead
await Socket.Init();
// A Socket can be created when needed.
// Here we are creating a socket.io Socket at startup and registering it as a service
// below tells the socket the uri of our socketio-demo-server
var socket = new Socket("http://localhost:3000");
builder.Services.AddSingleton(socket);
// example of listening for a message on a Socket
socket.On<string>("welcome", welcomeMessage =>
{
Console.WriteLine($"Welcome received: {welcomeMessage}");
});await builder.Build().RunAsync();
```
Counter.razor
```cs
@page "/counter"
@inject Socket Socket
@implements IDisposable<PageTitle>Shared Counter</PageTitle>
<h1>Shared Counter</h1>
<p role="status">Current count: @currentCount</p>
<p role="status">Changed by: @countChangedBy</p><button disabled="@Socket.Disconnected" class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private string countChangedBy = "";private void IncrementCount()
{
Socket.Emit("incrementCount");
}
protected override void OnInitialized()
{
Socket.OnConnect += Socket_OnConnect;
Socket.OnDisconnect += Socket_OnDisconnect;
Socket.On<string, int>("countChanged", Socket_OnCountChanged);
_ = TryUpdateCount();
}
void Socket_OnCountChanged(string changedBy, int newValue)
{
currentCount = newValue;
countChangedBy = changedBy;
StateHasChanged();
}
async Task TryUpdateCount()
{
if (!Socket.Connected) return;
try
{
(countChangedBy, currentCount) = await Socket.EmitWithAck<(string, int)>("getCount");
StateHasChanged();
}
catch { }
}
void Socket_OnConnect()
{
_ = TryUpdateCount();
}
void Socket_OnDisconnect()
{
StateHasChanged();
}
public void Dispose()
{
Socket.OnConnect -= Socket_OnConnect;
Socket.OnDisconnect -= Socket_OnDisconnect;
Socket.Off<string, int>("countChanged", Socket_OnCountChanged);
}
}
```### The NodeJS Socket.IO server (socketio-demo-server)
**app.js**
```js
const { createServer } = require("http");
const { Server } = require("socket.io");const httpServer = createServer();
const io = new Server(httpServer, {
// options
cors: { origin: '*', },
});
const port = 3000;let currentCount = 0;
let countChangedBy = "";io.on("connection", (socket) => {
console.log("socket connection", socket.id);
// send a welcome message
socket.emit("welcome", `Welcome to my server! ${socket.id}`);
// listen for disconnect
socket.on("disconnect", () => {
console.log("socket disconnect", socket.id);
});
socket.on("incrementCount", () => {
// request to increase count
// increase and notify all sockets
currentCount++;
countChangedBy = socket.id;
// notify all sockets
io.emit("countChanged", countChangedBy, currentCount);
});
socket.on("getCount", (callback) => {
// request for current count
callback([countChangedBy, currentCount]);
});
// listen for events messages
socket.on("getWeather", function (callback) {
console.log("socket getWeather", socket.id);
var weather = [
{
"date": "2022-01-06",
"temperatureC": 1,
"summary": "Freezing"
},
{
"date": "2022-01-07",
"temperatureC": 14,
"summary": "Bracing"
},
{
"date": "2022-01-08",
"temperatureC": -13,
"summary": "Freezing"
},
{
"date": "2022-01-09",
"temperatureC": -16,
"summary": "Balmy"
},
{
"date": "2022-01-10",
"temperatureC": -2,
"summary": "Chilly"
}
];
callback(weather);
});
});// listen
httpServer.listen(port, function () {
console.log(`Listening on port ${port}`);
});
```