This commit is contained in:
27
frontend/app/composables/api.js
Normal file
27
frontend/app/composables/api.js
Normal file
@@ -0,0 +1,27 @@
|
||||
// composables/useApi.js
|
||||
import { ref } from 'vue'
|
||||
|
||||
export default function useApi() {
|
||||
const config = useRuntimeConfig()
|
||||
const baseUrl = config.public.apiBaseUrl
|
||||
|
||||
// Generic GET request
|
||||
const get = async (endpoint) => {
|
||||
const res = await fetch(`${baseUrl}${endpoint}`)
|
||||
if (!res.ok) throw new Error(`API GET ${endpoint} failed`)
|
||||
return res.json()
|
||||
}
|
||||
|
||||
// Generic POST request
|
||||
const post = async (endpoint, payload) => {
|
||||
const res = await fetch(`${baseUrl}${endpoint}`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify(payload)
|
||||
})
|
||||
if (!res.ok) throw new Error(`API POST ${endpoint} failed`)
|
||||
return res.json()
|
||||
}
|
||||
|
||||
return { get, post }
|
||||
}
|
||||
Reference in New Issue
Block a user