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:
sct
2020-09-13 00:01:38 +09:00
committed by GitHub
parent 342d1a3c75
commit 1910876706
9 changed files with 184 additions and 15 deletions

View File

@@ -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);
}