Merge pull request #30 from Der-Penz/feature/append-result
Feature: append_to_result support
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "tmdb-ts",
|
||||
"version": "1.0.0",
|
||||
"version": "1.1.0",
|
||||
"description": "TMDB v3 library wrapper",
|
||||
"main": "dist/index.js",
|
||||
"types": "dist/index.d.ts",
|
||||
|
||||
@@ -1,20 +1,20 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { ChangeOptions, Changes } from '../types/changes';
|
||||
import { ChangeOptions, MediaChanges } from '../types/changes';
|
||||
|
||||
export class ChangeEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async movies(options?: ChangeOptions): Promise<Changes> {
|
||||
return await this.api.get<Changes>(`/movie/changes`, options);
|
||||
async movies(options?: ChangeOptions): Promise<MediaChanges> {
|
||||
return await this.api.get<MediaChanges>(`/movie/changes`, options);
|
||||
}
|
||||
|
||||
async tvShows(options?: ChangeOptions): Promise<Changes> {
|
||||
return await this.api.get<Changes>(`/tv/changes`, options);
|
||||
async tvShows(options?: ChangeOptions): Promise<MediaChanges> {
|
||||
return await this.api.get<MediaChanges>(`/tv/changes`, options);
|
||||
}
|
||||
|
||||
async person(options?: ChangeOptions): Promise<Changes> {
|
||||
return await this.api.get<Changes>(`/person/change`, options);
|
||||
async person(options?: ChangeOptions): Promise<MediaChanges> {
|
||||
return await this.api.get<MediaChanges>(`/person/change`, options);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,14 +1,16 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import {
|
||||
AlternativeTitles,
|
||||
AppendToResponse,
|
||||
AppendToResponseMovieKey,
|
||||
ChangeOptions,
|
||||
Changes,
|
||||
Credits,
|
||||
ExternalIds,
|
||||
Images,
|
||||
Keywords,
|
||||
LanguageOption,
|
||||
LatestMovie,
|
||||
MovieChanges,
|
||||
MovieDetails,
|
||||
MovieLists,
|
||||
MoviesPlayingNow,
|
||||
@@ -33,8 +35,20 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(id: number): Promise<MovieDetails> {
|
||||
return await this.api.get<MovieDetails>(`${BASE_MOVIE}/${id}`);
|
||||
async details<T extends AppendToResponseMovieKey[] | undefined>(
|
||||
id: number,
|
||||
appendToResponse?: T
|
||||
) {
|
||||
const options = {
|
||||
append_to_response: appendToResponse
|
||||
? appendToResponse.join(',')
|
||||
: undefined,
|
||||
};
|
||||
|
||||
return await this.api.get<AppendToResponse<MovieDetails, T, 'movie'>>(
|
||||
`${BASE_MOVIE}/${id}`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles> {
|
||||
@@ -43,11 +57,8 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
);
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<MovieChanges> {
|
||||
return await this.api.get<MovieChanges>(
|
||||
`${BASE_MOVIE}/${id}/changes`,
|
||||
options
|
||||
);
|
||||
async changes(id: number, options?: ChangeOptions): Promise<Changes> {
|
||||
return await this.api.get<Changes>(`${BASE_MOVIE}/${id}/changes`, options);
|
||||
}
|
||||
|
||||
async credits(id: number): Promise<Credits> {
|
||||
|
||||
@@ -1,12 +1,14 @@
|
||||
import {
|
||||
AppendToResponse,
|
||||
AppendToResponsePersonKey,
|
||||
ChangeOptions,
|
||||
ExternalIds,
|
||||
Image,
|
||||
PageOption,
|
||||
PeopleTranslations,
|
||||
PeopleImages,
|
||||
PersonTranslations,
|
||||
PersonChanges,
|
||||
PersonCombinedCredits,
|
||||
PersonDetail,
|
||||
PersonDetails,
|
||||
PersonMovieCredit,
|
||||
PersonTvShowCredit,
|
||||
PopularPersons,
|
||||
@@ -21,8 +23,19 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(id: number): Promise<PersonDetail> {
|
||||
return await this.api.get<PersonDetail>(`${BASE_PERSON}/${id}`);
|
||||
async details<T extends AppendToResponsePersonKey[] | undefined>(
|
||||
id: number,
|
||||
appendToResponse?: T
|
||||
) {
|
||||
const options = {
|
||||
append_to_response: appendToResponse
|
||||
? appendToResponse.join(',')
|
||||
: undefined,
|
||||
};
|
||||
return await this.api.get<AppendToResponse<PersonDetails, T, 'person'>>(
|
||||
`${BASE_PERSON}/${id}`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<PersonChanges> {
|
||||
@@ -54,10 +67,8 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
return await this.api.get<ExternalIds>(`${BASE_PERSON}/${id}/external_ids`);
|
||||
}
|
||||
|
||||
async images(id: number): Promise<{ id: number; profiles: Image[] }> {
|
||||
return await this.api.get<{ id: number; profiles: Image[] }>(
|
||||
`${BASE_PERSON}/${id}/images`
|
||||
);
|
||||
async images(id: number): Promise<PeopleImages> {
|
||||
return await this.api.get<PeopleImages>(`${BASE_PERSON}/${id}/images`);
|
||||
}
|
||||
|
||||
async taggedImages(id: number, options?: PageOption): Promise<TaggedImages> {
|
||||
@@ -67,14 +78,14 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
);
|
||||
}
|
||||
|
||||
async translation(id: number): Promise<PeopleTranslations> {
|
||||
return await this.api.get<PeopleTranslations>(
|
||||
async translation(id: number): Promise<PersonTranslations> {
|
||||
return await this.api.get<PersonTranslations>(
|
||||
`${BASE_PERSON}/${id}/translations`
|
||||
);
|
||||
}
|
||||
|
||||
async latest(): Promise<PersonDetail> {
|
||||
return await this.api.get<PersonDetail>(`${BASE_PERSON}/latest`);
|
||||
async latest(): Promise<PersonDetails> {
|
||||
return await this.api.get<PersonDetails>(`${BASE_PERSON}/latest`);
|
||||
}
|
||||
|
||||
async popular(options?: PageOption): Promise<PopularPersons> {
|
||||
|
||||
@@ -1,7 +1,10 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import {
|
||||
AlternativeTitles,
|
||||
AppendToResponse,
|
||||
AppendToResponseTvKey,
|
||||
ChangeOptions,
|
||||
Changes,
|
||||
ContentRatings,
|
||||
Credits,
|
||||
EpisodeGroups,
|
||||
@@ -21,7 +24,6 @@ import {
|
||||
SimilarTvShows,
|
||||
TopRatedTvShows,
|
||||
Translations,
|
||||
TvShowChanges,
|
||||
TvShowDetails,
|
||||
TvShowsAiringToday,
|
||||
Videos,
|
||||
@@ -35,8 +37,19 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(id: number): Promise<TvShowDetails> {
|
||||
return await this.api.get<TvShowDetails>(`${BASE_TV}/${id}`);
|
||||
async details<T extends AppendToResponseTvKey[] | undefined>(
|
||||
id: number,
|
||||
appendToResponse?: T
|
||||
) {
|
||||
const options = {
|
||||
append_to_response: appendToResponse
|
||||
? appendToResponse.join(',')
|
||||
: undefined,
|
||||
};
|
||||
return await this.api.get<AppendToResponse<TvShowDetails, T, 'tvShow'>>(
|
||||
`${BASE_TV}/${id}`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles> {
|
||||
@@ -45,11 +58,8 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
);
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<TvShowChanges> {
|
||||
return await this.api.get<TvShowChanges>(
|
||||
`${BASE_TV}/${id}/changes`,
|
||||
options
|
||||
);
|
||||
async changes(id: number, options?: ChangeOptions): Promise<Changes> {
|
||||
return await this.api.get<Changes>(`${BASE_TV}/${id}/changes`, options);
|
||||
}
|
||||
|
||||
async contentRatings(id: number): Promise<ContentRatings> {
|
||||
|
||||
@@ -1,10 +1,10 @@
|
||||
export interface Change {
|
||||
export interface MediaChange {
|
||||
id: number;
|
||||
adult: boolean | undefined;
|
||||
}
|
||||
|
||||
export interface Changes {
|
||||
results: Change[];
|
||||
export interface MediaChanges {
|
||||
results: MediaChange[];
|
||||
page: number;
|
||||
total_pages: number;
|
||||
total_results: number;
|
||||
@@ -15,3 +15,21 @@ export interface ChangeOptions {
|
||||
start_date?: string;
|
||||
page?: number;
|
||||
}
|
||||
|
||||
export interface Changes {
|
||||
changes: Change[];
|
||||
}
|
||||
|
||||
export interface Change {
|
||||
key: string;
|
||||
items: ChangeItem[];
|
||||
}
|
||||
|
||||
export interface ChangeItem {
|
||||
id: string;
|
||||
action: string;
|
||||
time: string;
|
||||
value: Array<number>;
|
||||
iso_639_1: string;
|
||||
original_value: Array<number>;
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
export interface Images {
|
||||
export interface ImageConfiguration {
|
||||
base_url: string;
|
||||
secure_base_url: string;
|
||||
backdrop_sizes: BackdropSizes[];
|
||||
@@ -9,7 +9,7 @@ export interface Images {
|
||||
}
|
||||
|
||||
export interface Configuration {
|
||||
images: Images;
|
||||
images: ImageConfiguration;
|
||||
change_keys: ChangeKeys[];
|
||||
}
|
||||
|
||||
|
||||
@@ -128,6 +128,7 @@ export interface ContentRatings {
|
||||
}
|
||||
|
||||
export interface ContentRatingsResult {
|
||||
descriptor: unknown[];
|
||||
iso_3166_1: string;
|
||||
rating: string;
|
||||
}
|
||||
@@ -202,3 +203,10 @@ export interface Image {
|
||||
vote_count: number;
|
||||
width: number;
|
||||
}
|
||||
|
||||
export interface Images {
|
||||
id: number;
|
||||
backdrops: Image[];
|
||||
logos: Image[];
|
||||
posters: Image[];
|
||||
}
|
||||
|
||||
@@ -94,24 +94,6 @@ export interface MovieLists {
|
||||
total_results: number;
|
||||
}
|
||||
|
||||
export interface MovieChangeItem {
|
||||
id: string;
|
||||
action: string;
|
||||
time: string;
|
||||
iso_639_1: string;
|
||||
value: string;
|
||||
original_value: string;
|
||||
}
|
||||
|
||||
export interface MovieChange {
|
||||
key: string;
|
||||
items: MovieChangeItem[];
|
||||
}
|
||||
|
||||
export interface MovieChanges {
|
||||
changes: MovieChange[];
|
||||
}
|
||||
|
||||
export interface LatestMovie {
|
||||
adult: boolean;
|
||||
backdrop_path?: string;
|
||||
|
||||
@@ -1,3 +1,31 @@
|
||||
import {
|
||||
AlternativeTitles,
|
||||
Changes,
|
||||
ContentRatings,
|
||||
Credits,
|
||||
EpisodeGroups,
|
||||
ExternalIds,
|
||||
Images,
|
||||
Keywords,
|
||||
MovieLists,
|
||||
PeopleImages,
|
||||
PersonTranslations,
|
||||
PersonChanges,
|
||||
PersonCombinedCredits,
|
||||
PersonMovieCredit,
|
||||
PersonTvShowCredit,
|
||||
Recommendations,
|
||||
ReleaseDates,
|
||||
Reviews,
|
||||
ScreenedTheatrically,
|
||||
SimilarMovies,
|
||||
SimilarTvShows,
|
||||
TaggedImages,
|
||||
Translations,
|
||||
Videos,
|
||||
WatchProviders,
|
||||
} from '.';
|
||||
|
||||
export interface LanguageOption {
|
||||
language?: string;
|
||||
}
|
||||
@@ -9,3 +37,147 @@ export interface RegionOption {
|
||||
export interface PageOption {
|
||||
page?: number;
|
||||
}
|
||||
|
||||
export type AppendToResponseMovieKey =
|
||||
| 'images'
|
||||
| 'videos'
|
||||
| 'credits'
|
||||
| 'recommendations'
|
||||
| 'reviews'
|
||||
| 'changes'
|
||||
| 'similar'
|
||||
| 'lists'
|
||||
| 'release_dates'
|
||||
| 'alternative_titles'
|
||||
| 'external_ids'
|
||||
| 'translations'
|
||||
| 'watch/providers'
|
||||
| 'keywords';
|
||||
|
||||
export type AppendToResponseTvKey =
|
||||
| 'content_ratings'
|
||||
| 'images'
|
||||
| 'videos'
|
||||
| 'credits'
|
||||
| 'recommendations'
|
||||
| 'reviews'
|
||||
| 'changes'
|
||||
| 'similar'
|
||||
| 'alternative_titles'
|
||||
| 'external_ids'
|
||||
| 'translations'
|
||||
| 'watch/providers'
|
||||
| 'aggregate_credits'
|
||||
| 'episode_groups'
|
||||
| 'screened_theatrically'
|
||||
| 'keywords';
|
||||
|
||||
export type AppendToResponsePersonKey =
|
||||
| 'images'
|
||||
| 'changes'
|
||||
| 'movie_credits'
|
||||
| 'tv_credits'
|
||||
| 'combined_credits'
|
||||
| 'external_ids'
|
||||
| 'tagged_images'
|
||||
| 'translations';
|
||||
|
||||
type AppendToResponseAllKeys =
|
||||
| AppendToResponseTvKey
|
||||
| AppendToResponseMovieKey
|
||||
| AppendToResponsePersonKey;
|
||||
|
||||
export type AppendToResponseMediaType = 'movie' | 'tvShow' | 'person';
|
||||
|
||||
export type AppendToResponse<
|
||||
K,
|
||||
T extends AppendToResponseAllKeys[] | undefined,
|
||||
Media extends AppendToResponseMediaType
|
||||
> = K &
|
||||
(T extends undefined
|
||||
? object
|
||||
: T extends Array<unknown>
|
||||
? ('credits' extends T[number]
|
||||
? { credits: Omit<Credits, 'id'> }
|
||||
: object) &
|
||||
('videos' extends T[number] ? { videos: Omit<Videos, 'id'> } : object) &
|
||||
('images' extends T[number]
|
||||
? {
|
||||
images: Omit<
|
||||
Media extends 'person' ? PeopleImages : Images,
|
||||
'id'
|
||||
>;
|
||||
}
|
||||
: object) &
|
||||
('recommendations' extends T[number]
|
||||
? { recommendations: Recommendations }
|
||||
: object) &
|
||||
('reviews' extends T[number]
|
||||
? { reviews: Omit<Reviews, 'id'> }
|
||||
: object) &
|
||||
('reviews' extends T[number]
|
||||
? { reviews: Omit<Translations, 'id'> }
|
||||
: object) &
|
||||
('changes' extends T[number]
|
||||
? {
|
||||
changes: Omit<
|
||||
Media extends 'person' ? PersonChanges : Changes,
|
||||
'id'
|
||||
>;
|
||||
}
|
||||
: object) &
|
||||
('keywords' extends T[number]
|
||||
? { keywords: Omit<Keywords, 'id'> }
|
||||
: object) &
|
||||
('lists' extends T[number]
|
||||
? { lists: Omit<MovieLists, 'id'> }
|
||||
: object) &
|
||||
('release_dates' extends T[number]
|
||||
? { release_dates: Omit<ReleaseDates, 'id'> }
|
||||
: object) &
|
||||
('alternative_titles' extends T[number]
|
||||
? { alternative_titles: Omit<AlternativeTitles, 'id'> }
|
||||
: object) &
|
||||
('external_ids' extends T[number]
|
||||
? { external_ids: Omit<ExternalIds, 'id'> }
|
||||
: object) &
|
||||
('translations' extends T[number]
|
||||
? { translations: Omit<Media extends 'person' ? PersonTranslations : Translations, 'id'> }
|
||||
: object) &
|
||||
('watch/providers' extends T[number]
|
||||
? { 'watch/providers': Omit<WatchProviders, 'id'> }
|
||||
: object) &
|
||||
('aggregate_credits' extends T[number]
|
||||
? { aggregate_credits: Omit<Credits, 'id'> }
|
||||
: object) &
|
||||
('episode_groups' extends T[number]
|
||||
? { episode_groups: Omit<EpisodeGroups, 'id'> }
|
||||
: object) &
|
||||
('screened_theatrically' extends T[number]
|
||||
? { screened_theatrically: Omit<ScreenedTheatrically, 'id'> }
|
||||
: object) &
|
||||
('similar' extends T[number]
|
||||
? {
|
||||
similar: Media extends 'movie'
|
||||
? SimilarMovies
|
||||
: Media extends 'tvShow'
|
||||
? SimilarTvShows
|
||||
: unknown;
|
||||
}
|
||||
: object) &
|
||||
('content_ratings' extends T[number]
|
||||
? { content_ratings: Omit<ContentRatings, 'id'> }
|
||||
: object) &
|
||||
('movie_credits' extends T[number]
|
||||
? { movie_credits: Omit<PersonMovieCredit, 'id'> }
|
||||
: object) &
|
||||
('tv_credits' extends T[number]
|
||||
? { tv_credits: Omit<PersonTvShowCredit, 'id'> }
|
||||
: object) &
|
||||
('combined_credits' extends T[number]
|
||||
? { combined_credits: Omit<PersonCombinedCredits, 'id'> }
|
||||
: object) &
|
||||
('tagged_images' extends T[number]
|
||||
? { tagged_images: TaggedImages }
|
||||
: object)
|
||||
: never);
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { Movie, Person, TV } from '.';
|
||||
import { Image, Movie, Person, TV } from '.';
|
||||
|
||||
interface Cast {
|
||||
character: string;
|
||||
@@ -79,7 +79,7 @@ export interface PersonCombinedCredits {
|
||||
id: number;
|
||||
}
|
||||
|
||||
export interface PersonDetail {
|
||||
export interface PersonDetails {
|
||||
birthday: string;
|
||||
known_for_department: string;
|
||||
deathday: string;
|
||||
@@ -120,6 +120,11 @@ export interface PopularPersons {
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
export interface PeopleImages {
|
||||
id: number;
|
||||
profiles: Image[];
|
||||
}
|
||||
|
||||
export interface TaggedImage {
|
||||
aspect_ratio: number;
|
||||
file_path: string;
|
||||
@@ -141,7 +146,7 @@ export interface TaggedImages {
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
export interface PeopleTranslations {
|
||||
export interface PersonTranslations {
|
||||
id: number;
|
||||
translations: {
|
||||
iso_3166_1: string;
|
||||
|
||||
@@ -134,24 +134,6 @@ export interface SeasonDetails {
|
||||
season_number: number;
|
||||
}
|
||||
|
||||
export interface TvShowItem {
|
||||
id: string;
|
||||
action: string;
|
||||
time: string;
|
||||
value: Array<number>;
|
||||
iso_639_1: string;
|
||||
original_value: Array<number>;
|
||||
}
|
||||
|
||||
export interface TvShowChange {
|
||||
key: string;
|
||||
items: TvShowItem[];
|
||||
}
|
||||
|
||||
export interface TvShowChanges {
|
||||
changes: TvShowChange[];
|
||||
}
|
||||
|
||||
export interface Network {
|
||||
id: number;
|
||||
logo_path: string;
|
||||
|
||||
Reference in New Issue
Block a user