Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rodgc/ngx-socket-io
Socket.IO module for Angular
https://github.com/rodgc/ngx-socket-io
angular angular2 angular4 javascript ngx-socket-io socket socket-io tyepscript
Last synced: 1 day ago
JSON representation
Socket.IO module for Angular
- Host: GitHub
- URL: https://github.com/rodgc/ngx-socket-io
- Owner: rodgc
- License: mit
- Created: 2017-06-01T02:18:47.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-27T17:48:14.000Z (15 days ago)
- Last Synced: 2025-01-02T21:07:29.033Z (9 days ago)
- Topics: angular, angular2, angular4, javascript, ngx-socket-io, socket, socket-io, tyepscript
- Language: TypeScript
- Homepage:
- Size: 553 KB
- Stars: 261
- Watchers: 18
- Forks: 91
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-angular - ngx-socket-io - [Socket.IO](https://socket.io/) module for Angular. (Table of contents / Angular)
- fucking-awesome-angular - ngx-socket-io - 🌎 [Socket.IO](socket.io/) module for Angular. (Table of contents / Angular)
- fucking-awesome-angular - ngx-socket-io - 🌎 [Socket.IO](socket.io/) module for Angular. (Table of contents / Angular)
README
# ngx-socket-io
[![Build Status](https://travis-ci.org/rodgc/ngx-socket-io.svg?branch=master)](https://travis-ci.org/rodgc/ngx-socket-io)
[![npm version](https://badge.fury.io/js/ngx-socket-io.svg)](https://badge.fury.io/js/ngx-socket-io)
[![npm downloads](https://img.shields.io/badge/Downloads-132%2Fmonth-brightgreen.svg)](https://github.com/rodgc/ngx-socket-io)[Socket.IO](http://socket.io/) module for Angular
## Install
`npm install ngx-socket-io`
**Important:**
Make sure you're using the proper corresponding version of socket.io on the server.
| Package Version | Socket-io Server Version | Angular version |
| --------------- | ------------------------ | --------------- |
| v3.4.0 | v2.2.0 | |
| v4.1.0 | v4.0.0 | 12.x |
| v4.2.0 | v4.0.0 | 13.x |
| v4.3.0 | v4.5.1 | 14.x |
| v4.4.0 | v4.5.1 | 15.x |
| v4.5.0 | v4.5.1 | 16.x |
| v4.6.1 | v4.7.2 | 17.x |
| v4.7.0 | v4.7.2 | 18.x |
| v4.8.1 | v4.8.1 | 19.x |## How to use
### Import and configure SocketIoModule for NgModule based applications
```ts
import { SocketIoModule, SocketIoConfig } from 'ngx-socket-io';const config: SocketIoConfig = { url: 'http://localhost:8988', options: {} };
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, SocketIoModule.forRoot(config)],
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
```We need to configure `SocketIoModule` module using the object `config` of type `SocketIoConfig`, this object accepts two optional properties they are the same used here [io(url[, options])](https://socket.io/docs/v4/client-initialization/#Options).
Now we pass the configuration to the static method `forRoot` of `SocketIoModule`
### Import and configure SocketIoModule for standalone based applications
In app.config.ts use the following:
```ts
import { ApplicationConfig, importProvidersFrom } from '@angular/core';
import { SocketIoModule, SocketIoConfig } from 'ngx-socket-io';const config: SocketIoConfig = { url: 'http://localhost:8988', options: {} };
export const appConfig: ApplicationConfig = {
providers: [importProvidersFrom(SocketIoModule.forRoot(config))],
};
```For standalone applications we do not have the AppModule where we can import the `SocketIoModule`. Instead we can use the `importProvidersFrom` provided by angular to provide the `SocketIoModule` to our application. The usage of the socket instance is then the same as if we used a NgModule based application.
### Using your socket Instance
The `SocketIoModule` provides now a configured `Socket` service that can be injected anywhere inside the `AppModule`.
```typescript
import { Injectable } from '@angular/core';
import { Socket } from 'ngx-socket-io';
import { map } from 'rxjs/operators';@Injectable()
export class ChatService {
constructor(private socket: Socket) {}sendMessage(msg: string) {
this.socket.emit('message', msg);
}
getMessage() {
return this.socket.fromEvent('message').pipe(map(data => data.msg));
}
}
```### Using multiple sockets with different end points
In this case we do not configure the `SocketIoModule` directly using `forRoot`. What we have to do is: extend the `Socket` service, and call `super()` with the `SocketIoConfig` object type (passing `url` & `options` if any).
```typescript
import { Injectable, NgModule } from '@angular/core';
import { Socket } from 'ngx-socket-io';@Injectable()
export class SocketOne extends Socket {
constructor() {
super({ url: 'http://url_one:portOne', options: {} });
}
}@Injectable()
export class SocketTwo extends Socket {
constructor() {
super({ url: 'http://url_two:portTwo', options: {} });
}
}@NgModule({
declarations: [
//components
],
imports: [
SocketIoModule,
//...
],
providers: [SocketOne, SocketTwo],
bootstrap: [
/** AppComponent **/
],
})
export class AppModule {}
```Now you can inject `SocketOne`, `SocketTwo` in any other services and / or components.
## API
Most of the functionalities here you are already familiar with.
The only addition is the `fromEvent` method, which returns an `Observable` that you can subscribe to.
### `socket.of(namespace: string)`
Takes a namespace and returns an instance based on the current config and the given namespace,
that is added to the end of the current url.
See [Namespaces - Client Initialization](https://socket.io/docs/v4/namespaces/#client-initialization).
Instances are reused based on the namespace.### `socket.on(eventName: string, callback: Function)`
Takes an event name and callback.
Works the same as in Socket.IO.### `socket.removeListener(eventName: string, callback?: Function)`
Takes an event name and callback.
Works the same as in Socket.IO.### `socket.removeAllListeners(eventName?: string)`
Takes an event name.
Works the same as in Socket.IO.### `socket.emit(eventName:string, ...args: any[])`
Sends a message to the server.
Works the same as in Socket.IO.### `socket.fromEvent(eventName: string): Observable`
Takes an event name and returns an Observable that you can subscribe to.
### `socket.fromOneTimeEvent(eventName: string): Promise`
Creates a Promise for a one-time event.
You should keep a reference to the Observable subscription and unsubscribe when you're done with it.
This prevents memory leaks as the event listener attached will be removed (using `socket.removeListener`) ONLY and when/if you unsubscribe.If you have multiple subscriptions to an Observable only the last unsubscription will remove the listener.
## Know Issue
For `error TS2345` you need to add this to your `tsconfig.json`.
```json
{
...
"compilerOptions": {
...
"paths": {
"rxjs": ["node_modules/rxjs"]
}
},
}
```## Related projects
- [bougarfaoui/ng-socket-io](https://github.com/bougarfaoui/ng-socket-io) - Socket.IO module for Angular
## LICENSE
MIT