SWR

You should have an OpenAPI specification and an Orval config where you define the mode as swr.

Example with SWR

module.exports = {
petstore: {
output: {
mode: 'tags-split',
target: 'src/petstore.ts',
schemas: 'src/model',
client: 'swr',
mock: true,
},
input: {
target: './petstore.yaml',
},
},
};

Checkout the orval config reference to see all available options.

The SWR model will generate an implementation file with one custom hook per path in your OpenAPI Specification.

Like the following example from this swagger:

export const showPetById = (
petId: string,
options?: AxiosRequestConfig,
): Promise<AxiosResponse<Pet>> => {
return axios.get(`/pets/${petId}`, options);
};
export const getShowPetByIdKey = (petId: string) => [`/pets/${petId}`];
Re;
export const useShowPetById = <TError = Error>(
petId: string,
options?: {
swr?: SWRConfiguration<AsyncReturnType<typeof showPetById>, TError> & {
swrKey?: Key;
enabled?: boolean;
};
axios?: AxiosRequestConfig;
},
) => {
const { swr: swrOptions, axios: axiosOptions } = options ?? {};
const isEnabled = swrOptions?.enabled !== false && !!petId;
const swrKey =
swrOptions?.swrKey ?? (() => (isEnabled ? getShowPetByIdKey(petId) : null));
const swrFn = () => showPetById(petId, axiosOptions);
const query = useSwr<AsyncReturnType<typeof swrFn>, TError>(
swrKey,
swrFn,
swrOptions,
);
return {
swrKey,
...query,
};
};

Checkout here the full example

Was this page helpful?

Copyright © 2025 Victor Bury. All Rights Reserved.