first commit
Some checks failed
Build / run (push) Has been cancelled

This commit is contained in:
maher
2025-10-29 11:42:25 +01:00
commit 703f50a09d
4595 changed files with 385164 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
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 {UseFormReturn} from 'react-hook-form';
import {onFormQueryError} from '@common/errors/on-form-query-error';
import {Video, VideoCaption} from '@app/titles/models/video';
interface Response extends BackendResponse {
video: Video;
}
export interface CreateVideoPayload {
name: string;
title_id: number;
season_num?: number;
episode_num?: number;
thumbnail?: string;
type: Video['type'];
src: string;
quality: Video['quality'];
language: string;
category: Video['category'];
captions?: VideoCaption[];
}
export function useCreateVideo(form: UseFormReturn<CreateVideoPayload>) {
return useMutation({
mutationFn: (payload: CreateVideoPayload) => createVideo(payload),
onSuccess: async () => {
await queryClient.invalidateQueries({queryKey: ['video']});
},
onError: r => (form ? onFormQueryError(r, form) : showHttpErrorToast(r)),
});
}
function createVideo(payload: CreateVideoPayload): Promise<Response> {
return apiClient.post(`videos`, payload).then(r => r.data);
}

View File

@@ -0,0 +1,26 @@
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';
interface Response extends BackendResponse {
//
}
interface Payload {
videoIds: number[];
}
export function useDeleteVideos() {
return useMutation({
mutationFn: (payload: Payload) => deleteVideos(payload),
onSuccess: async () => {
await queryClient.invalidateQueries({queryKey: ['video']});
},
onError: r => showHttpErrorToast(r),
});
}
function deleteVideos({videoIds}: Payload): Promise<Response> {
return apiClient.delete(`videos/${videoIds.join(',')}`).then(r => r.data);
}

View File

@@ -0,0 +1,30 @@
import {BackendResponse} from '@common/http/backend-response/backend-response';
import {useMutation} from '@tanstack/react-query';
import {apiClient, queryClient} from '@common/http/query-client';
import {UseFormReturn} from 'react-hook-form';
import {onFormQueryError} from '@common/errors/on-form-query-error';
import {Video} from '@app/titles/models/video';
import {CreateVideoPayload} from '@app/admin/videos/requests/use-create-video';
import {useParams} from 'react-router-dom';
interface Response extends BackendResponse {
video: Video;
}
export function useUpdateVideo(form: UseFormReturn<CreateVideoPayload>) {
const {videoId} = useParams();
return useMutation({
mutationFn: (payload: CreateVideoPayload) => updateVideo(videoId!, payload),
onSuccess: async () => {
await queryClient.invalidateQueries({queryKey: ['video']});
},
onError: r => onFormQueryError(r, form),
});
}
function updateVideo(
videoId: string | number,
payload: CreateVideoPayload,
): Promise<Response> {
return apiClient.put(`videos/${videoId}`, payload).then(r => r.data);
}

View File

@@ -0,0 +1,23 @@
import {useQuery} from '@tanstack/react-query';
import {apiClient} from '@common/http/query-client';
import {BackendResponse} from '@common/http/backend-response/backend-response';
import {Video} from '@app/titles/models/video';
import {useParams} from 'react-router-dom';
interface Response extends BackendResponse {
video: Video;
}
export function useVideo() {
const {videoId} = useParams();
return useQuery({
queryKey: ['video', `${videoId}`],
queryFn: () => fetchVideo(videoId!),
});
}
function fetchVideo(videoId: number | string) {
return apiClient
.get<Response>(`videos/${videoId}`)
.then(response => response.data);
}