Request Model (#79)
* feat(api): request model Also adds request binding to search/discover results * fix(api): rename Request to MediaRequest and update nextjs tsconfig * refactor(api): move related request fetching code into MediaRequest entity
This commit is contained in:
@@ -3,6 +3,7 @@ import type {
|
||||
TmdbPersonResult,
|
||||
TmdbTvResult,
|
||||
} from '../api/themoviedb';
|
||||
import { MediaRequest } from '../entity/MediaRequest';
|
||||
|
||||
export type MediaType = 'tv' | 'movie' | 'person';
|
||||
|
||||
@@ -17,6 +18,7 @@ interface SearchResult {
|
||||
genreIds: number[];
|
||||
overview: string;
|
||||
originalLanguage: string;
|
||||
request?: MediaRequest;
|
||||
}
|
||||
|
||||
export interface MovieResult extends SearchResult {
|
||||
@@ -26,6 +28,7 @@ export interface MovieResult extends SearchResult {
|
||||
releaseDate: string;
|
||||
adult: boolean;
|
||||
video: boolean;
|
||||
request?: MediaRequest;
|
||||
}
|
||||
|
||||
export interface TvResult extends SearchResult {
|
||||
@@ -48,7 +51,10 @@ export interface PersonResult {
|
||||
|
||||
export type Results = MovieResult | TvResult | PersonResult;
|
||||
|
||||
export const mapMovieResult = (movieResult: TmdbMovieResult): MovieResult => ({
|
||||
export const mapMovieResult = (
|
||||
movieResult: TmdbMovieResult,
|
||||
request?: MediaRequest
|
||||
): MovieResult => ({
|
||||
id: movieResult.id,
|
||||
mediaType: 'movie',
|
||||
adult: movieResult.adult,
|
||||
@@ -64,9 +70,13 @@ export const mapMovieResult = (movieResult: TmdbMovieResult): MovieResult => ({
|
||||
voteCount: movieResult.vote_count,
|
||||
backdropPath: movieResult.backdrop_path,
|
||||
posterPath: movieResult.poster_path,
|
||||
request,
|
||||
});
|
||||
|
||||
export const mapTvResult = (tvResult: TmdbTvResult): TvResult => ({
|
||||
export const mapTvResult = (
|
||||
tvResult: TmdbTvResult,
|
||||
request?: MediaRequest
|
||||
): TvResult => ({
|
||||
id: tvResult.id,
|
||||
firstAirDate: tvResult.first_air_Date,
|
||||
genreIds: tvResult.genre_ids,
|
||||
@@ -81,6 +91,7 @@ export const mapTvResult = (tvResult: TmdbTvResult): TvResult => ({
|
||||
voteCount: tvResult.vote_count,
|
||||
backdropPath: tvResult.backdrop_path,
|
||||
posterPath: tvResult.poster_path,
|
||||
request,
|
||||
});
|
||||
|
||||
export const mapPersonResult = (
|
||||
@@ -102,14 +113,21 @@ export const mapPersonResult = (
|
||||
});
|
||||
|
||||
export const mapSearchResults = (
|
||||
results: (TmdbMovieResult | TmdbTvResult | TmdbPersonResult)[]
|
||||
results: (TmdbMovieResult | TmdbTvResult | TmdbPersonResult)[],
|
||||
requests?: MediaRequest[]
|
||||
): Results[] =>
|
||||
results.map((result) => {
|
||||
switch (result.media_type) {
|
||||
case 'movie':
|
||||
return mapMovieResult(result);
|
||||
return mapMovieResult(
|
||||
result,
|
||||
requests?.find((req) => req.mediaId === result.id)
|
||||
);
|
||||
case 'tv':
|
||||
return mapTvResult(result);
|
||||
return mapTvResult(
|
||||
result,
|
||||
requests?.find((req) => req.mediaId === result.id)
|
||||
);
|
||||
default:
|
||||
return mapPersonResult(result);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user