Skip to content

Commit

Permalink
feat: support reactive body (closes #20)
Browse files Browse the repository at this point in the history
  • Loading branch information
johannschopplich committed May 6, 2023
1 parent 10a92a6 commit 92ef27f
Showing 1 changed file with 11 additions and 11 deletions.
22 changes: 11 additions & 11 deletions src/runtime/composables/useApiData.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import { computed, reactive, unref } from 'vue'
import { computed, reactive } from 'vue'
import { hash } from 'ohash'
import type { FetchError } from 'ofetch'
import type { NitroFetchOptions } from 'nitropack'
import type { Ref } from 'vue'
import type { AsyncData, AsyncDataOptions } from 'nuxt/app'
import type { ModuleOptions } from '../../module'
import { headersToObject, serializeMaybeEncodedBody, toValue } from '../utils'
Expand All @@ -14,8 +13,8 @@ type ComputedOptions<T extends Record<string, any>> = {
[K in keyof T]: T[K] extends Function
? T[K]
: T[K] extends Record<string, any>
? ComputedOptions<T[K]> | Ref<T[K]> | T[K]
: Ref<T[K]> | T[K];
? ComputedOptions<T[K]> | MaybeRef<T[K]>
: MaybeRef<T[K]>;
}

export type UseApiDataOptions<T> = AsyncDataOptions<T> & Pick<
Expand All @@ -28,7 +27,7 @@ export type UseApiDataOptions<T> = AsyncDataOptions<T> & Pick<
| 'headers'
| 'method'
> & {
body?: string | Record<string, any> | FormData | null
body?: MaybeRef<string | Record<string, any> | FormData | null | undefined>
/**
* Skip the Nuxt server proxy and fetch directly from the API.
* Requires `allowClient` to be enabled in the module options as well.
Expand Down Expand Up @@ -82,8 +81,9 @@ export function _useApiData<T = any>(
const _endpointFetchOptions: EndpointFetchOptions = reactive({
path: _path,
query,
headers: computed(() => headersToObject(unref(headers as MaybeRef<HeadersInit>))),
headers: computed(() => headersToObject(toValue(headers))),
method,
body,
})

const _asyncDataOptions: AsyncDataOptions<T> = {
Expand All @@ -103,9 +103,9 @@ export function _useApiData<T = any>(
const key = computed(() => `$party${hash([
endpointId,
_path.value,
unref(query),
unref(method),
...(isFormData(body) ? [] : [body]),
toValue(query),
toValue(method),
...(isFormData(toValue(body)) ? [] : [toValue(body)]),
])}`)

return useAsyncData<T, FetchError>(
Expand Down Expand Up @@ -138,7 +138,7 @@ export function _useApiData<T = any>(
...endpoint.headers,
..._endpointFetchOptions.headers,
},
body,
body: _endpointFetchOptions.body,
})) as T
}
else {
Expand All @@ -150,7 +150,7 @@ export function _useApiData<T = any>(
method: 'POST',
body: {
..._endpointFetchOptions,
body: await serializeMaybeEncodedBody(body),
body: await serializeMaybeEncodedBody(_endpointFetchOptions.body),
} satisfies EndpointFetchOptions,
},
)) as T
Expand Down

0 comments on commit 92ef27f

Please sign in to comment.