Files
ember-market-frontend/lib/client-utils.ts
2025-02-07 21:33:13 +00:00

32 lines
988 B
TypeScript

/**
* Simple client-side fetch function for making API calls with Authorization header.
*/
export async function clientFetch(url: string, options: RequestInit = {}): Promise<any> {
try {
const authToken = document.cookie
.split('; ')
.find(row => row.startsWith('Authorization='))
?.split('=')[1] || localStorage.getItem('Authorization');
console.log('authToken', authToken);
// Merge Authorization header if token is found
const headers = {
'Content-Type': 'application/json',
...(authToken ? { Authorization: `Bearer ${authToken}` } : {}),
...options.headers,
};
const res = await fetch(`${process.env.NEXT_PUBLIC_API_URL}${url}`, {
...options,
headers,
});
if (!res.ok) throw new Error(`Request failed: ${res.statusText}`);
return res.json();
} catch (error) {
console.error(`Client fetch error at ${url}:`, error);
throw error;
}
}