Files
mtdb_movie/resources/client/reviews/requests/use-create-review.ts
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

46 lines
1.4 KiB
TypeScript
Executable File

import {BackendResponse} from '@common/http/backend-response/backend-response';
import {useMutation} from '@tanstack/react-query';
import {apiClient, queryClient} from '@common/http/query-client';
import {showHttpErrorToast} from '@common/utils/http/show-http-error-toast';
import {Review} from '@app/titles/models/review';
import {Reviewable} from '@app/reviews/reviewable';
import {UseFormReturn} from 'react-hook-form';
import {onFormQueryError} from '@common/errors/on-form-query-error';
import {reviewsQueryKey} from '@app/reviews/requests/use-reviews';
interface Response extends BackendResponse {
review: Review;
}
export interface CreateReviewPayload {
score: number;
title?: string;
body?: string;
}
interface Payload extends CreateReviewPayload {
reviewable: Reviewable;
}
export function useCreateReview(form?: UseFormReturn<CreateReviewPayload>) {
return useMutation({
mutationFn: (payload: Payload) => createReview(payload),
onSuccess: async () => {
await queryClient.invalidateQueries({queryKey: reviewsQueryKey()});
},
onError: r => (form ? onFormQueryError(r, form) : showHttpErrorToast(r)),
});
}
function createReview(payload: Payload): Promise<Response> {
return apiClient
.post(`reviews`, {
reviewable_id: payload.reviewable.id,
reviewable_type: payload.reviewable.model_type,
score: payload.score,
title: payload.title,
body: payload.body,
})
.then(r => r.data);
}