From 47587812b809fee2a95c76266d9d0e42fc4ac1ca Mon Sep 17 00:00:00 2001 From: crupest Date: Tue, 15 Jun 2021 14:14:28 +0800 Subject: ... --- FrontEnd/src/http/bookmark.ts | 49 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 FrontEnd/src/http/bookmark.ts (limited to 'FrontEnd/src/http/bookmark.ts') diff --git a/FrontEnd/src/http/bookmark.ts b/FrontEnd/src/http/bookmark.ts new file mode 100644 index 00000000..3e5be229 --- /dev/null +++ b/FrontEnd/src/http/bookmark.ts @@ -0,0 +1,49 @@ +import { axios, apiBaseUrl, extractResponseData } from "./common"; + +import { HttpTimelineInfo } from "./timeline"; + +export interface HttpHighlightMoveRequest { + timeline: string; + newPosition: number; +} + +export interface IHttpBookmarkClient { + list(): Promise; + put(timeline: string): Promise; + delete(timeline: string): Promise; + move(req: HttpHighlightMoveRequest): Promise; +} + +export class HttpHighlightClient implements IHttpBookmarkClient { + list(): Promise { + return axios + .get(`${apiBaseUrl}/bookmarks`) + .then(extractResponseData); + } + + put(timeline: string): Promise { + return axios.put(`${apiBaseUrl}/bookmarks/${timeline}`).then(); + } + + delete(timeline: string): Promise { + return axios.delete(`${apiBaseUrl}/bookmarks/${timeline}`).then(); + } + + move(req: HttpHighlightMoveRequest): Promise { + return axios.post(`${apiBaseUrl}/bookmarkop/move`, req).then(); + } +} + +let client: IHttpBookmarkClient = new HttpHighlightClient(); + +export function getHttpBookmarkClient(): IHttpBookmarkClient { + return client; +} + +export function setHttpBookmarkClient( + newClient: IHttpBookmarkClient +): IHttpBookmarkClient { + const old = client; + client = newClient; + return old; +} -- cgit v1.2.3