32 lines
712 B
TypeScript
32 lines
712 B
TypeScript
import type { APIError } from "./types";
|
|
|
|
const apiBase = process.env.API_BASE ?? "/api";
|
|
|
|
export default async function fetchAPI<T>(
|
|
path: string,
|
|
method = "GET",
|
|
body: any = null
|
|
) {
|
|
let headers = {};
|
|
const token =
|
|
typeof localStorage !== "undefined" &&
|
|
localStorage.getItem("pronouns-token");
|
|
if (token) {
|
|
headers = {
|
|
Authorization: token,
|
|
};
|
|
}
|
|
|
|
const resp = await fetch(`${apiBase}/v1${path}`, {
|
|
method,
|
|
headers: {
|
|
...headers,
|
|
"Content-Type": "application/json",
|
|
},
|
|
body: body ? JSON.stringify(body) : null,
|
|
});
|
|
|
|
const data = await resp.json();
|
|
if (resp.status < 200 || resp.status >= 300) throw data as APIError;
|
|
return data as T;
|
|
}
|