Skip to content

Instantly share code, notes, and snippets.

@uno-de-piera
Created January 6, 2018 21:30
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save uno-de-piera/8b4bc22d286e02b8d194bd8722093c1d to your computer and use it in GitHub Desktop.
Save uno-de-piera/8b4bc22d286e02b8d194bd8722093c1d to your computer and use it in GitHub Desktop.
import { Injectable }from '@angular/core';
import { HttpClient, HttpHeaders }from '@angular/common/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/throw';
import 'rxjs/add/operator/catch';
import {User} from './user';
const cudOptions = { headers: new HttpHeaders({ 'Content-Type': 'application/json' })};
@Injectable()
export class UsersService {
private usersUrl: string = '/api/users';
constructor (private http: HttpClient) {}
getUsers (): Observable<User[]> {
return this.http.get<User[]>(this.usersUrl)
.catch(this.handleError);
}
getUser(id: string): Observable<User> {
const url = `${this.usersUrl}/${id}`;
return this.http.get<User[]>(url)
.catch(this.handleError);
}
addUser (user: User): Observable<User> {
const newUser = Object.assign({}, user);
return this.http.post<User>(this.usersUrl, newUser, cudOptions)
.catch(this.handleError);
}
deleteUser (user: User | number): Observable<User> {
const id = typeof user === 'number' ? user : user.id;
const url = `${this.usersUrl}/${id}`;
return this.http.delete<User>(url, cudOptions)
.catch(this.handleError);
}
updateUser (user: User): Observable<null> {
return this.http.put(this.usersUrl, user, cudOptions)
.catch(this.handleError);
}
private handleError (error: any) {
console.error(error);
return Observable.throw(error);
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment