1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/model/network.service.ts
2016-04-27 22:37:07 +02:00

56 lines
1.8 KiB
TypeScript

///<reference path="../../browser.d.ts"/>
import {Http, Headers, RequestOptions, Response} from "angular2/http";
import {Message} from "../../../common/entities/Message";
import "rxjs/Rx";
import {Utils} from "../../../common/Utils";
export class NetworkService{
_baseUrl = "/api";
constructor(protected _http:Http){
}
private callJson<T>(method:string, url:string, data:any = {}): Promise<T>{
let body = JSON.stringify( data );
let headers = new Headers({ 'Content-Type': 'application/json' });
let options = new RequestOptions({ headers: headers });
if(method == "get"){
return this._http[method](this._baseUrl+url, options)
.toPromise()
.then(res => <Message<any>> res.json())
.catch(NetworkService.handleError);
}
return this._http[method](this._baseUrl+url, body, options)
.toPromise()
.then(res => <Message<any>> res.json())
.catch(NetworkService.handleError);
}
protected postJson<T>(url:string, data:any = {}): Promise<T>{
return this.callJson("post",url,data);
}
protected putJson<T>(url:string, data:any = {}): Promise<T>{
return this.callJson("put",url,data);
}
protected getJson<T>(url:string): Promise<T>{
return this.callJson("get",url);
}
protected deleteJson<T>(url:string, data:any = {}): Promise<T>{
return this.callJson("delete",url,data);
}
private static handleError (error: any) {
// in a real world app, we may send the error to some remote logging infrastructure
// instead of just logging it to the console
console.error(error);
return Promise.reject(error.message || error.json().error || 'Server error');
}
}