mirror of
https://github.com/seerr-team/seerr.git
synced 2026-03-16 06:27:38 -04:00
* feat: add quotas, advanced options, and toggles to collection request modal * fix: use correct requiredquota strings * refactor: clean up collection part request status logic * revert: undo changes to effect dependencies * fix(lang): tweak TV request modal request button strings * fix: don't try to fetch other users' quotas without MANAGE_USERS perm
72 lines
1.8 KiB
TypeScript
72 lines
1.8 KiB
TypeScript
import React from 'react';
|
|
import type { MediaStatus } from '../../../server/constants/media';
|
|
import { MediaRequest } from '../../../server/entity/MediaRequest';
|
|
import Transition from '../Transition';
|
|
import CollectionRequestModal from './CollectionRequestModal';
|
|
import MovieRequestModal from './MovieRequestModal';
|
|
import TvRequestModal from './TvRequestModal';
|
|
|
|
interface RequestModalProps {
|
|
show: boolean;
|
|
type: 'movie' | 'tv' | 'collection';
|
|
tmdbId: number;
|
|
is4k?: boolean;
|
|
editRequest?: MediaRequest;
|
|
onComplete?: (newStatus: MediaStatus) => void;
|
|
onCancel?: () => void;
|
|
onUpdating?: (isUpdating: boolean) => void;
|
|
}
|
|
|
|
const RequestModal: React.FC<RequestModalProps> = ({
|
|
type,
|
|
show,
|
|
tmdbId,
|
|
is4k,
|
|
editRequest,
|
|
onComplete,
|
|
onUpdating,
|
|
onCancel,
|
|
}) => {
|
|
return (
|
|
<Transition
|
|
enter="transition opacity-0 duration-300"
|
|
enterFrom="opacity-0"
|
|
enterTo="opacity-100"
|
|
leave="transition opacity-100 duration-300"
|
|
leaveFrom="opacity-100"
|
|
leaveTo="opacity-0"
|
|
show={show}
|
|
>
|
|
{type === 'movie' ? (
|
|
<MovieRequestModal
|
|
onComplete={onComplete}
|
|
onCancel={onCancel}
|
|
tmdbId={tmdbId}
|
|
onUpdating={onUpdating}
|
|
is4k={is4k}
|
|
editRequest={editRequest}
|
|
/>
|
|
) : type === 'tv' ? (
|
|
<TvRequestModal
|
|
onComplete={onComplete}
|
|
onCancel={onCancel}
|
|
tmdbId={tmdbId}
|
|
onUpdating={onUpdating}
|
|
is4k={is4k}
|
|
editRequest={editRequest}
|
|
/>
|
|
) : (
|
|
<CollectionRequestModal
|
|
onComplete={onComplete}
|
|
onCancel={onCancel}
|
|
tmdbId={tmdbId}
|
|
onUpdating={onUpdating}
|
|
is4k={is4k}
|
|
/>
|
|
)}
|
|
</Transition>
|
|
);
|
|
};
|
|
|
|
export default RequestModal;
|