mirror of
https://github.com/aaronpo97/the-biergarten-app.git
synced 2026-02-16 10:42:08 +00:00
43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import CommentQueryResult from '@/services/types/CommentSchema/CommentQueryResult';
|
|
import CreateCommentValidationSchema from '@/services/types/CommentSchema/CreateCommentValidationSchema';
|
|
|
|
import APIResponseValidationSchema from '@/validation/APIResponseValidationSchema';
|
|
import { z } from 'zod';
|
|
|
|
const BeerCommentValidationSchemaWithId = CreateCommentValidationSchema.extend({
|
|
beerPostId: z.string().uuid(),
|
|
});
|
|
|
|
const sendCreateBeerCommentRequest = async ({
|
|
beerPostId,
|
|
content,
|
|
rating,
|
|
}: z.infer<typeof BeerCommentValidationSchemaWithId>) => {
|
|
const response = await fetch(`/api/beers/${beerPostId}/comments`, {
|
|
method: 'POST',
|
|
headers: { 'Content-Type': 'application/json' },
|
|
body: JSON.stringify({ beerPostId, content, rating }),
|
|
});
|
|
if (!response.ok) {
|
|
throw new Error(response.statusText);
|
|
}
|
|
|
|
const data = await response.json();
|
|
|
|
const parsedResponse = APIResponseValidationSchema.safeParse(data);
|
|
|
|
if (!parsedResponse.success) {
|
|
throw new Error('Invalid API response');
|
|
}
|
|
|
|
const parsedPayload = CommentQueryResult.safeParse(parsedResponse.data.payload);
|
|
|
|
if (!parsedPayload.success) {
|
|
throw new Error('Invalid API response payload');
|
|
}
|
|
|
|
return parsedPayload.data;
|
|
};
|
|
|
|
export default sendCreateBeerCommentRequest;
|