mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
d0f6ca3bac
* chore: Updated Setup Script for Splitting Env File * chore: updated dockerfile for using inproject env varaibles * chore: removed husky replacement script * chore: updated shell script using sed * chore: updated dockerfiles with removed cp statement * chore: added example env for apiserver * chore: refactored secret generation for backend * chore: removed replacement script * chore: updated docker-compose with removed env variables * chore: resolved comments in setup.sh and docker-compose * chore: removed secret key placeholder in apiserver example env * chore: updated root env for project less env variables * chore: removed project level env update from root env logic * chore: updated API_BASE_URL in .env.example * chore: restored docker argument as env NEXT_PUBLIC_API_BASE_URL * chore: added pg missing env variables * [chore] Updated web and deploy backend configuration for reverse proxy & decoupled Plane Deploy URL generation for web (#2135) * chore: removed api url build arg from compose * chore: set public api default argument to black string for self hosted * chore: updated web services to accept blank string as API URL * chore: added env variables for pg compose service * chore: modified space app services to use accept empty string as api base * chore: conditionally trigger web url value based on argument * fix: made web to use identical host with spaces suffix on absense of Deploy URL for deploy * chore: added example env for PUBLIC_DEPLOY Env * chore: updated web dockerfile with addition as PLANE_DEPLOY Argument * API BASE URL global update * API BASE URL replace with api server * api base url fixes * typo fixes --------- Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> * dev: remove API_BASE_URL from environment variable --------- Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> Co-authored-by: pablohashescobar <nikhilschacko@gmail.com>
193 lines
5.2 KiB
TypeScript
193 lines
5.2 KiB
TypeScript
// services
|
|
import APIService from "services/api.service";
|
|
// types
|
|
import type {
|
|
IUserNotification,
|
|
INotificationParams,
|
|
NotificationCount,
|
|
PaginatedUserNotification,
|
|
IMarkAllAsReadPayload,
|
|
} from "types";
|
|
// helpers
|
|
import { API_BASE_URL } from "helpers/common.helper";
|
|
|
|
class UserNotificationsServices extends APIService {
|
|
constructor() {
|
|
super(API_BASE_URL);
|
|
}
|
|
|
|
async getUserNotifications(
|
|
workspaceSlug: string,
|
|
params: INotificationParams
|
|
): Promise<IUserNotification[]> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/users/notifications`, {
|
|
params,
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserNotificationDetailById(
|
|
workspaceSlug: string,
|
|
notificationId: string
|
|
): Promise<IUserNotification> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async markUserNotificationAsRead(
|
|
workspaceSlug: string,
|
|
notificationId: string
|
|
): Promise<IUserNotification> {
|
|
return this.post(`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/read/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async markUserNotificationAsUnread(
|
|
workspaceSlug: string,
|
|
notificationId: string
|
|
): Promise<IUserNotification> {
|
|
return this.delete(
|
|
`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/read/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async markUserNotificationAsArchived(
|
|
workspaceSlug: string,
|
|
notificationId: string
|
|
): Promise<IUserNotification> {
|
|
return this.post(
|
|
`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/archive/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async markUserNotificationAsUnarchived(
|
|
workspaceSlug: string,
|
|
notificationId: string
|
|
): Promise<IUserNotification> {
|
|
return this.delete(
|
|
`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/archive/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async patchUserNotification(
|
|
workspaceSlug: string,
|
|
notificationId: string,
|
|
data: Partial<IUserNotification>
|
|
): Promise<IUserNotification> {
|
|
return this.patch(
|
|
`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/`,
|
|
data
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async deleteUserNotification(workspaceSlug: string, notificationId: string): Promise<any> {
|
|
return this.delete(`/api/workspaces/${workspaceSlug}/users/notifications/${notificationId}/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async subscribeToIssueNotifications(
|
|
workspaceSlug: string,
|
|
projectId: string,
|
|
issueId: string
|
|
): Promise<any> {
|
|
return this.post(
|
|
`/api/workspaces/${workspaceSlug}/projects/${projectId}/issues/${issueId}/subscribe/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getIssueNotificationSubscriptionStatus(
|
|
workspaceSlug: string,
|
|
projectId: string,
|
|
issueId: string
|
|
): Promise<{
|
|
subscribed: boolean;
|
|
}> {
|
|
return this.get(
|
|
`/api/workspaces/${workspaceSlug}/projects/${projectId}/issues/${issueId}/subscribe/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async unsubscribeFromIssueNotifications(
|
|
workspaceSlug: string,
|
|
projectId: string,
|
|
issueId: string
|
|
): Promise<any> {
|
|
return this.delete(
|
|
`/api/workspaces/${workspaceSlug}/projects/${projectId}/issues/${issueId}/subscribe/`
|
|
)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUnreadNotificationsCount(workspaceSlug: string): Promise<NotificationCount> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/users/notifications/unread/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getNotifications(url: string): Promise<PaginatedUserNotification> {
|
|
return this.get(url)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async markAllNotificationsAsRead(
|
|
workspaceSlug: string,
|
|
payload: IMarkAllAsReadPayload
|
|
): Promise<any> {
|
|
return this.post(`/api/workspaces/${workspaceSlug}/users/notifications/mark-all-read/`, {
|
|
...payload,
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
}
|
|
|
|
const userNotificationServices = new UserNotificationsServices();
|
|
|
|
export default userNotificationServices;
|