// services import { USER_ENDPOINT, USER_ISSUES_ENDPOINT, USER_ONBOARD_ENDPOINT } from "constants/api-routes"; import APIService from "lib/services/api.service"; import type { IUser } from "types"; const { NEXT_PUBLIC_API_BASE_URL } = process.env; class UserService extends APIService { constructor() { super(NEXT_PUBLIC_API_BASE_URL || "http://localhost:8000"); } currentUserConfig() { return { url: `${this.baseURL}/api/users/me/`, headers: this.getHeaders(), }; } async userIssues(workspaceSlug: string): Promise { return this.get(USER_ISSUES_ENDPOINT(workspaceSlug)) .then((response) => { return response?.data; }) .catch((error) => { throw error?.response?.data; }); } async currentUser(): Promise { if (!this.getAccessToken()) return null; return this.get(USER_ENDPOINT) .then((response) => { return response?.data; }) .catch((error) => { this.purgeAccessToken(); throw error?.response?.data; }); } async updateUser(data: Partial): Promise { return this.patch(USER_ENDPOINT, data) .then((response) => { return response?.data; }) .catch((error) => { throw error?.response?.data; }); } async updateUserOnBoard(): Promise { return this.patch(USER_ONBOARD_ENDPOINT, { is_onboarded: true }) .then((response) => { return response?.data; }) .catch((error) => { throw error?.response?.data; }); } } export default new UserService();