mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
0d3b8823e4
adding thumbnail loader for faces
151 lines
4.6 KiB
TypeScript
151 lines
4.6 KiB
TypeScript
import {Injectable} from '@angular/core';
|
|
import {HttpClient, HttpResponse} from '@angular/common/http';
|
|
import {Message} from '../../../../common/entities/Message';
|
|
import {SlimLoadingBarService} from 'ng2-slim-loading-bar';
|
|
import {ErrorCodes, ErrorDTO} from '../../../../common/entities/Error';
|
|
import {Config} from '../../../../common/config/public/Config';
|
|
import {Utils} from '../../../../common/Utils';
|
|
import {CostumHeaders} from '../../../../common/CostumHeaders';
|
|
import {VersionService} from '../version.service';
|
|
|
|
@Injectable()
|
|
export class NetworkService {
|
|
|
|
_apiBaseUrl = Utils.concatUrls(Config.Client.urlBase, '/api');
|
|
private globalErrorHandlers: Array<(error: ErrorDTO) => boolean> = [];
|
|
|
|
constructor(private _http: HttpClient,
|
|
private slimLoadingBarService: SlimLoadingBarService,
|
|
private versionService: VersionService) {
|
|
}
|
|
|
|
public static buildUrl(url: string, data?: { [key: string]: any }) {
|
|
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 url;
|
|
}
|
|
|
|
public getXML<T>(url: string): Promise<Document> {
|
|
|
|
this.slimLoadingBarService.visible = true;
|
|
this.slimLoadingBarService.start(() => {
|
|
this.slimLoadingBarService.visible = false;
|
|
});
|
|
|
|
const process = (res: string): Document => {
|
|
this.slimLoadingBarService.complete();
|
|
const parser = new DOMParser();
|
|
return parser.parseFromString(res, 'text/xml');
|
|
};
|
|
|
|
const err = (error: any) => {
|
|
this.slimLoadingBarService.complete();
|
|
return this.handleError(error);
|
|
};
|
|
|
|
return this._http.get(this._apiBaseUrl + url, {responseType: 'text'})
|
|
.toPromise()
|
|
.then(process)
|
|
.catch(err);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
public getJson<T>(url: string, data?: { [key: string]: any }): Promise<T> {
|
|
return this.callJson('get', NetworkService.buildUrl(url, data));
|
|
}
|
|
|
|
public deleteJson<T>(url: string): Promise<T> {
|
|
return this.callJson('delete', url);
|
|
}
|
|
|
|
addGlobalErrorHandler(fn: (error: ErrorDTO) => boolean) {
|
|
this.globalErrorHandlers.push(fn);
|
|
}
|
|
|
|
private callJson<T>(method: 'get' | 'post' | 'delete' | 'put', url: string, data: any = {}): Promise<T> {
|
|
const body = data;
|
|
|
|
this.slimLoadingBarService.visible = true;
|
|
this.slimLoadingBarService.start(() => {
|
|
this.slimLoadingBarService.visible = false;
|
|
});
|
|
|
|
const process = (res: HttpResponse<Message<T>>): T => {
|
|
this.slimLoadingBarService.complete();
|
|
const msg = res.body;
|
|
if (res.headers.has(CostumHeaders.dataVersion)) {
|
|
this.versionService.onNewVersion(res.headers.get(CostumHeaders.dataVersion));
|
|
}
|
|
if (!!msg.error) {
|
|
if (msg.error.code) {
|
|
(<any>msg.error)['title'] = ErrorCodes[msg.error.code];
|
|
}
|
|
throw msg.error;
|
|
}
|
|
return msg.result;
|
|
};
|
|
|
|
const err = (error: any) => {
|
|
this.slimLoadingBarService.complete();
|
|
return this.handleError(error);
|
|
};
|
|
|
|
switch (method) {
|
|
case 'get':
|
|
return this._http.get<Message<T>>(this._apiBaseUrl + url, {observe: 'response'})
|
|
.toPromise()
|
|
.then(process)
|
|
.catch(err);
|
|
case 'delete':
|
|
return this._http.delete<Message<T>>(this._apiBaseUrl + url, {observe: 'response'})
|
|
.toPromise()
|
|
.then(process)
|
|
.catch(err);
|
|
case 'post':
|
|
return this._http.post<Message<T>>(this._apiBaseUrl + url, body, {observe: 'response'})
|
|
.toPromise()
|
|
.then(process)
|
|
.catch(err);
|
|
case 'put':
|
|
return this._http.put<Message<T>>(this._apiBaseUrl + url, body, {observe: 'response'})
|
|
.toPromise()
|
|
.then(process)
|
|
.catch(err);
|
|
default:
|
|
throw new Error('Unknown method');
|
|
}
|
|
|
|
}
|
|
|
|
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;
|
|
}
|
|
}
|
|
return Promise.reject(error);
|
|
}
|
|
// instead of just logging it to the console
|
|
console.error('error:', error);
|
|
return Promise.reject(error.message || error || 'Server error');
|
|
}
|
|
}
|