31 lines
808 B
JavaScript
31 lines
808 B
JavaScript
|
|
import { queryClient } from './queryClient'
|
||
|
|
|
||
|
|
const API_BASE_URL = import.meta.env.VITE_API_URL || 'http://localhost:3001/api'
|
||
|
|
|
||
|
|
export const api = {
|
||
|
|
get: async (endpoint) => {
|
||
|
|
const response = await fetch(`${API_BASE_URL}${endpoint}`)
|
||
|
|
if (!response.ok) {
|
||
|
|
throw new Error(`API error: ${response.statusText}`)
|
||
|
|
}
|
||
|
|
return response.json()
|
||
|
|
},
|
||
|
|
|
||
|
|
post: async (endpoint, data) => {
|
||
|
|
const response = await fetch(`${API_BASE_URL}${endpoint}`, {
|
||
|
|
method: 'POST',
|
||
|
|
headers: {
|
||
|
|
'Content-Type': 'application/json',
|
||
|
|
},
|
||
|
|
body: JSON.stringify(data),
|
||
|
|
})
|
||
|
|
if (!response.ok) {
|
||
|
|
const errorData = await response.json()
|
||
|
|
throw new Error(errorData.error || `API error: ${response.statusText}`)
|
||
|
|
}
|
||
|
|
return response.json()
|
||
|
|
},
|
||
|
|
}
|
||
|
|
|
||
|
|
export { queryClient }
|