Spaces:
Running
Running
File size: 2,725 Bytes
b89a86e 1684141 b89a86e 1684141 b89a86e |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
import { QueryClient, QueryFunction } from "@tanstack/react-query";
async function throwIfResNotOk(res: Response) {
if (!res.ok) {
// Handle 401 errors by clearing authentication
if (res.status === 401) {
localStorage.removeItem('token');
localStorage.removeItem('user');
localStorage.removeItem('seller');
localStorage.removeItem('userType');
// Redirect to auth page if not already there
if (window.location.pathname !== '/auth') {
window.location.href = '/auth';
}
}
const text = (await res.text()) || res.statusText;
throw new Error(`${res.status}: ${text}`);
}
}
export async function apiRequest(
method: string,
url: string,
data?: unknown | undefined,
): Promise<Response> {
const token = localStorage.getItem('token');
const headers: Record<string, string> = {};
// Don't set Content-Type for FormData - let browser set it with proper boundary
if (data && !(data instanceof FormData)) {
headers["Content-Type"] = "application/json";
}
if (token) {
headers["Authorization"] = `Bearer ${token}`;
}
const res = await fetch(url, {
method,
headers,
body: data instanceof FormData ? data : (data ? JSON.stringify(data) : undefined),
credentials: "include",
});
await throwIfResNotOk(res);
return res;
}
type UnauthorizedBehavior = "returnNull" | "throw";
export const getQueryFn: <T>(options: {
on401: UnauthorizedBehavior;
}) => QueryFunction<T> =
({ on401: unauthorizedBehavior }) =>
async ({ queryKey }) => {
const token = localStorage.getItem('token');
const headers: Record<string, string> = {};
if (token) {
headers["Authorization"] = `Bearer ${token}`;
}
const res = await fetch(queryKey.join("/") as string, {
headers,
credentials: "include",
});
if (res.status === 401) {
// Handle 401 errors by clearing authentication
localStorage.removeItem('token');
localStorage.removeItem('user');
localStorage.removeItem('seller');
localStorage.removeItem('userType');
if (unauthorizedBehavior === "returnNull") {
return null;
}
// Redirect to auth page if not already there
if (window.location.pathname !== '/auth') {
window.location.href = '/auth';
}
}
await throwIfResNotOk(res);
return await res.json();
};
export const queryClient = new QueryClient({
defaultOptions: {
queries: {
queryFn: getQueryFn({ on401: "throw" }),
refetchInterval: false,
refetchOnWindowFocus: false,
staleTime: Infinity,
retry: false,
},
mutations: {
retry: false,
},
},
});
|