Files
ember-market-frontend/lib/client-utils.ts
2025-03-03 20:44:10 +00:00

39 lines
1.1 KiB
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');
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;
}
}
/**
* Get a cookie value by name
*/
export function getCookie(name: string): string | undefined {
return document.cookie
.split('; ')
.find(row => row.startsWith(`${name}=`))
?.split('=')[1];
}