An angular module for using the sails socket.io api in angular2 (@angular)
Angular-cli is a great angular2 app starter for creating fancy angular stuff.
Here I will describe on how to install and use it:
install the package with the node package manager (npm)
npm install --save angular2-sails
Here you may add a line of code, to add the package to your vendor files
var Angular2App = require('angular-cli/lib/broccoli/angular2-app');
module.exports = function (defaults) {
return new Angular2App(defaults, {
vendorNpmFiles: [
...
'angular2-sails/dist/**/*.+(js|js.map)',
]
})
;
};
Here you have to register the module in the systemJS configuration and define the mapping location and the entry point.
/** Map relative paths to URLs. */
const map:any = {
...
'angular2-sails': 'vendor/angular2-sails/dist'
};
/** User packages configuration. */
const packages:any = {
...,
'angular2-sails': {
defaultExtension: 'js',
main: 'index.js'
},
}
import { SailsService } form 'angular2-sails';
You can provide the SailsService in a Component by the provider array or (not recommended) by providing it in the bootstrap of your application.
Example in Component:
import { Component, OnInit } from '@angular/core';
import { SailsService } from 'angular2-sails';
@Component({
moduleId: module.id,
selector: 'my',
templateUrl: 'my.component.html',
providers: [SailsService]
})
export class MyComponent implements OnInit {
constructor() { }
ngOnInit() { }
}
// and in a subcomponent of the provider component
import { Component, OnInit } from '@angular/core';
import { SailsService } from 'angular2-sails';
@Component({
moduleId: module.id,
selector: 'my-sub',
templateUrl: 'my-sub.component.html',
})
export class MySubComponent implements OnInit {
constructor(private _sailsService:SailsService) { }
ngOnInit() { }
}
Example in bootstrap (not recommended):
...
import { SailsService } from 'angular2-sails';
bootstrap(AppComponent, [
...,
SailsService
]);
// and then again in a component
import { Component, OnInit } from '@angular/core';
import { SailsService } from 'angular2-sails';
@Component({
moduleId: module.id,
selector: 'app',
templateUrl: 'app.component.html',
})
export class AppComponent implements OnInit {
constructor(private _sailsService:SailsService) { }
ngOnInit() { }
}
You inject the service by the constructor where you want to use it.
constructor(private _sailsService:SailsService) { }
first you have to connect your service:
ngOnInit() {
this._sailsService.connect()
}
you can pass in an Url or Options, where to connect to
ngOnInit() {
this._sailsService.connect("http://localhost:1337");
// or
letl opts = {
url: "http://localhost:1337",
transports: ['polling', 'websocket'],
headers: {...},
...
}
this._sailsService.connect(opts);
}
for more information, please visit sailsjs.org Documentation for SailsSocket Properties
this is handy, when you develop with angular-cli (localhost:4200) and the ng serve command and your sails app runs separately e.g on localhost:1337
The following methods are implemented in the SailsService and will always return you an Observable:
- get(path,data):Observable
- post(path,data):Observable
- put(path,data):Observable
- delete(path,data):Observable
- request(options):Observable
- on(eventEntity):Observable
for more information, please visit sailsjs.org Documentation for SailsSocket Methods
You then have to subscribe to that Observable, to get the data.
<ul>
<li *ngFor="let user of users">{{user.firstname}} {{user.lastname}}</li>
</ul>
import { Component, OnInit } from '@angular/core';
import { SailsService } from 'angular2-sails';
@Component({
moduleId: module.id,
selector: 'app',
templateUrl: 'app.component.html',
})
export class AppComponent implements OnInit {
// declare the variable for the template
public users:any[];
constructor(private _sailsService:SailsService) { }
ngOnInit() {
this._sailsService
.get('/users')
.subscribe(
(resData) => { this.users = resData},
(error) => { console.log("oooops, error occured") }
() => { console.log("we are finished") }
)
}
}
or even better, you use the async pipe of angular, and just pass the Observable to it
<ul>
<li *ngFor="let user of users$ | async">{{user.firstname}} {{user.lastname}}</li>
</ul>
import { Component, OnInit } from '@angular/core';
import { SailsService } from 'angular2-sails';
import { Observable } from "rxjs/Rx";
@Component({
moduleId: module.id,
selector: 'app',
templateUrl: 'app.component.html',
})
export class AppComponent implements OnInit {
// declare the variable for the template
public users$:Observable<any[]>;
constructor(private _sailsService:SailsService) { }
ngOnInit() {
// now we are passing the Observable to the template variable
this.users$ = this._sailsService.get('/users');
}
}