feat(projects): add client strip filtering and page refresh
This commit is contained in:
@@ -17,6 +17,7 @@ export interface Project {
|
||||
name: string;
|
||||
description: string;
|
||||
color: string;
|
||||
created_at?: string;
|
||||
is_archived: boolean;
|
||||
is_deleted?: boolean;
|
||||
workspace: string;
|
||||
@@ -33,24 +34,42 @@ export interface ProjectPayload {
|
||||
client: string | null;
|
||||
}
|
||||
|
||||
export const getProjects = async (
|
||||
workspaceId: string,
|
||||
params: { limit?: number; offset?: number; search?: string; client?: string; is_archived?: boolean, ordering?: string } = {}
|
||||
) => {
|
||||
const queryParams = new URLSearchParams({ workspace: workspaceId });
|
||||
export const getProjects = async (
|
||||
workspaceId: string,
|
||||
params: {
|
||||
limit?: number;
|
||||
offset?: number;
|
||||
search?: string;
|
||||
client?: string;
|
||||
clients?: string[];
|
||||
is_archived?: boolean;
|
||||
ordering?: string;
|
||||
} = {}
|
||||
) => {
|
||||
const queryParams = new URLSearchParams({ workspace: workspaceId });
|
||||
|
||||
if (params.limit !== undefined) queryParams.append("limit", params.limit.toString());
|
||||
if (params.offset !== undefined) queryParams.append("offset", params.offset.toString());
|
||||
if (params.search) queryParams.append("search", params.search);
|
||||
if (params.client) queryParams.append("client", params.client);
|
||||
if (params.is_archived !== undefined) queryParams.append("is_archived", params.is_archived.toString());
|
||||
if (params.search) queryParams.append("search", params.search);
|
||||
if (params.client) queryParams.append("client", params.client);
|
||||
params.clients?.forEach((clientId) => queryParams.append("clients", clientId));
|
||||
if (params.is_archived !== undefined) queryParams.append("is_archived", params.is_archived.toString());
|
||||
if (params.ordering !== undefined) queryParams.append("ordering", params.ordering.toString());
|
||||
|
||||
const response = await authFetch(`/api/projects/?${queryParams.toString()}`);
|
||||
|
||||
if (!response.ok) throw new Error("Failed to fetch projects");
|
||||
return response.json();
|
||||
};
|
||||
const response = await authFetch(`/api/projects/?${queryParams.toString()}`);
|
||||
|
||||
if (!response.ok) throw new Error("Failed to fetch projects");
|
||||
const data = await response.json();
|
||||
if (Array.isArray(data)) return data;
|
||||
if (Array.isArray(data?.items)) {
|
||||
return {
|
||||
...data,
|
||||
results: data.items,
|
||||
count: data.total_items ?? data.items.length,
|
||||
};
|
||||
}
|
||||
return data;
|
||||
};
|
||||
|
||||
export const getProject = async (id: string) => {
|
||||
const response = await authFetch(`/api/projects/${id}/`);
|
||||
|
||||
Reference in New Issue
Block a user