1 import { HttpErrorResponse } from '@angular/common/http'
2 import { Injectable } from '@angular/core'
3 import { dateToHuman } from '@app/shared/misc/utils'
4 import { Observable } from 'rxjs/Observable'
5 import { ResultList } from '../../../../../shared'
8 export class RestExtractor {
14 applyToResultListData <T> (result: ResultList<T>, fun: Function, additionalArgs?: any[]): ResultList<T> {
15 const data: T[] = result.data
16 const newData: T[] = []
18 data.forEach(d => newData.push(fun.apply(this, [ d ].concat(additionalArgs))))
26 convertResultListDateToHuman <T> (result: ResultList<T>, fieldsToConvert: string[] = [ 'createdAt' ]): ResultList<T> {
27 return this.applyToResultListData(result, this.convertDateToHuman, [ fieldsToConvert ])
30 convertDateToHuman (target: object, fieldsToConvert: string[]) {
31 fieldsToConvert.forEach(field => target[field] = dateToHuman(target[field]))
36 handleError (err: HttpErrorResponse) {
39 if (err.error instanceof Error) {
40 // A client-side or network error occurred. Handle it accordingly.
41 errorMessage = err.error.message
42 console.error('An error occurred:', errorMessage)
43 } else if (err.status !== undefined) {
44 // A server-side error occurred.
46 if (err.error.errors) {
47 const errors = err.error.errors
48 const errorsArray: string[] = []
50 Object.keys(errors).forEach(key => {
51 errorsArray.push(errors[key].msg)
54 errorMessage = errorsArray.join('. ')
55 } else if (err.error.error) {
56 errorMessage = err.error.error
58 } else if (err.status === 413) {
59 errorMessage = 'Request is too large for the server. Please contact you administrator if you want to increase the limit size.'
62 errorMessage = errorMessage ? errorMessage : 'Unknown error.'
63 console.error(`Backend returned code ${err.status}, body was: ${errorMessage}`)
69 message: errorMessage,
75 errorObj.status = err.status
76 errorObj.body = err.error
79 return Observable.throw(errorObj)