Instantly share code, notes, and snippets.

Embed
What would you like to do?
todo-list.service.ts
import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { TODOItem } from '@app/shared/models/todo-item';
import { of } from 'rxjs';
import { delay, first } from 'rxjs/operators';
@Injectable()
export class TodoListService {
private _todoList: TODOItem[] = [];
public get todoList(): TODOItem[] {
return this._todoList;
}
private todoListUrl = '//localhost:8080/api/todo-list';
private freshTodoListUrl = '//localhost:8080/api/fresh-todo-list';
constructor(private httpClient: HttpClient) {}
public getAndSetTodoList() {
this.httpClient
.get<Array<TODOItem>>(this.todoListUrl)
.pipe(first())
.subscribe((data) => {
this._todoList = data;
});
}
public getAndSetNewTodoList() {
this.httpClient
.get<Array<TODOItem>>(this.freshTodoListUrl)
.pipe(first())
.subscribe((data) => {
this._todoList = data;
});
}
public addTodo(todo: TODOItem) {
return of(null).pipe(delay(2000));
}
public updateTodo(todo: TODOItem) {
return of(null).pipe(delay(2000));
}
public deleteTodo(id: string) {
return of(null).pipe(delay(2000));
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment