1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/model/network/network.service.ts

106 lines
2.9 KiB
TypeScript
Raw Normal View History

2016-05-09 17:04:56 +02:00
import {Injectable} from "@angular/core";
import {Headers, Http, RequestOptions} from "@angular/http";
import {Message} from "../../../../common/entities/Message";
2017-06-22 21:23:26 +02:00
import {SlimLoadingBarService} from "ng2-slim-loading-bar";
2016-05-04 21:08:05 +02:00
import "rxjs/Rx";
import {ErrorCodes, ErrorDTO} from "../../../../common/entities/Error";
2016-03-12 22:19:24 +01:00
2016-05-04 21:08:05 +02:00
@Injectable()
2016-05-09 17:04:56 +02:00
export class NetworkService {
2016-03-12 22:19:24 +01:00
_baseUrl = "/api";
private globalErrorHandlers: Array<(error: ErrorDTO) => boolean> = [];
2016-03-12 22:19:24 +01:00
constructor(protected _http: Http,
private slimLoadingBarService: SlimLoadingBarService) {
}
2016-03-12 22:19:24 +01:00
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});
2016-03-13 11:28:29 +01:00
2017-06-21 21:16:04 +02:00
this.slimLoadingBarService.visible = true;
this.slimLoadingBarService.start(() => {
this.slimLoadingBarService.visible = false;
});
2017-07-03 19:17:49 +02:00
const process = (data: any): T => {
2017-06-21 21:16:04 +02:00
this.slimLoadingBarService.complete();
2017-07-03 19:17:49 +02:00
let res = <Message<any>> data.json();
if (!!res.error) {
if (res.error.code) {
res.error['title'] = ErrorCodes[res.error.code];
}
throw res.error;
}
return res.result;
2017-06-21 21:16:04 +02:00
};
const err = (err) => {
this.slimLoadingBarService.complete();
return this.handleError(err);
2017-06-21 21:16:04 +02:00
};
if (method == "get" || method == "delete") {
return <any>this._http[method](this._baseUrl + url, options)
.toPromise()
2017-06-21 21:16:04 +02:00
.then(process)
.catch(err);
}
return this._http[method](this._baseUrl + url, body, options)
.toPromise()
2017-06-21 21:16:04 +02:00
.then(process)
.catch(err);
}
2016-05-09 17:04:56 +02:00
public postJson<T>(url: string, data: any = {}): Promise<T> {
return this.callJson("post", url, data);
}
public putJson<T>(url: string, data: any = {}): Promise<T> {
return this.callJson("put", url, data);
}
2017-07-19 20:47:09 +02:00
public getJson<T>(url: string, data?: { [key: string]: any }): Promise<T> {
if (data) {
const keys = Object.getOwnPropertyNames(data);
if (keys.length > 0) {
url += "?";
for (let i = 0; i < keys.length; i++) {
url += keys[i] + "=" + data[keys[i]];
if (i < keys.length - 1) {
url += "&";
}
}
}
}
return this.callJson("get", url);
}
public deleteJson<T>(url: string): Promise<T> {
return this.callJson("delete", url);
}
private handleError(error: any) {
if (typeof error.code !== "undefined") {
for (let i = 0; i < this.globalErrorHandlers.length; i++) {
if (this.globalErrorHandlers[i](error) == true) {
return;
}
}
2017-07-12 18:31:19 +02:00
return Promise.reject(error);
}
// instead of just logging it to the console
console.error(error);
2017-07-03 19:17:49 +02:00
return Promise.reject(error.message || error || 'Server error');
}
addGlobalErrorHandler(fn: (error: ErrorDTO) => boolean) {
this.globalErrorHandlers.push(fn);
}
2016-03-12 22:19:24 +01:00
}